perm filename FILEX.MAC[CSP,SYS] blob sn#078239 filedate 1974-01-23 generic text, type C, neo UTF8
COMMENT ⊗   VALID 00121 PAGES
C REC  PAGE   DESCRIPTION
C00001 00001
C00011 00002	TITLE FILEX - GENERAL FILE TRANSFER ROUTINE - V15(4)
C00013 00003	LEFT HALF FLAGS
C00016 00004	EXTERN .JBFF,.JBREL
C00018 00005	START OF FILEX
C00021 00006	BEG0A:	TRNN T,1←14		BINARY SUPPORTED?
C00023 00007	BEG1:	MOVSI T1,0		SEE WHAT OUTPUT FORMAT TAPE IS, IF TAPE
C00026 00008	REINP:	TRZ F,R.IN		INITIALIZE THIS FLAG
C00029 00009	ASKI2:	CAIN T,(SIXBIT /*/)	WILD?
C00031 00010	HERE TO READ AND LIST A DIRECTORY BLOCK
C00034 00011	SEE IF WANT TO PUT TAPE ON SCRATCH FILE
C00037 00012	SCR1:	MOVEI A,17		GET DUMP MODE DISK FOR SCRATCH
C00039 00013	SCRRL:	CAMLE B,LASTBK		STILL SOME TO READ?
C00041 00014	TYPDIQ:	MOVE T,ISW		GET INPUT SWITCHES
C00043 00015	PDP-10 FORMAT DTA DIRECTORY LISTER
C00046 00016	OLD PDP6 FORMAT TAPE DIRECTORY LISTER
C00048 00017	PROJECT MAC DIRECTORY LISTER
C00050 00018		PUSHJ P,BLKCMC		COUNT BLOCKS IN THIS FILE
C00053 00019	PDP15 DIRECTORY LISTER
C00054 00020	DIRFL:	SKIPN T,DIRECT+20(C)
C00056 00021	PDP-11 DIRECTORY LISTER
C00058 00022	DIRVNN:	MOVE T,VWPEI		SEE IF NEXT FILE EXISTS
C00060 00023	TWO SUBRS TO GET WORD FROM PDP11 DIRECTORY.
C00061 00024	OUTASK:	TRNN F,R.OUT		ANY OUTPUT REQUESTED?
C00064 00025		HLLZS B			CLEAN UP AC'S
C00066 00026	OUTZR1:	TLNE F,L.DTVO		ELEVEN?
C00068 00027	OUTZRV:	SKIPN OPPN		OUTPUT PPN SPECIFIED?
C00071 00028	DAT104:	XWD 0,1			LINK,NUMBER OF PBM
C00074 00029	SELFIL:	TRNN F,R.IN		ANYTHING WANTED?
C00077 00030	SELFO:	SKIPL C,SRCHP		GET OFFSET INTO SIX DIRECTORY
C00079 00031	SELFT:	SKIPGE C,SRCHP		POINTER INTO TEN DIRECTORY
C00081 00032	SELFIF:	SKIPGE C,SRCHP		FILE INDEX
C00083 00033	SELFV:	SKIPGE C,SRCHP		STARTED?
C00085 00034	SELFVR:	PUSH P,C		SAVE INDEX
C00088 00035	SELFNT:	TLNE F,L.DSKI		NON TAPE. DISK?
C00091 00036	SELFD1:	PUSHJ P,URPB		READ A WORD FROM UFD
C00093 00037	SELFNW:	MOVE A,IFILE		HERE WHEN NEITHER WILD NOR DTA
C00095 00038	SELFW1:	MOVE D,IPPN		NEED A LOOKUP. GET DIRECTORY
C00098 00039	ENTR:	SETZM FOEXT		CLEAR FORCED OUTPUT EXTENSION
C00101 00040	ENTTEN:	TLNE F,L.SCRO		SCRATCH OUTPUT FILE?
C00104 00041	ENTTNW:
C00106 00042	ENTSIX:	MOVEI A,117		GET THE OUTPUT TAPE IN KLUDGE MODE
C00109 00043	ENTER ROUTINE FOR MAC TAPES
C00111 00044	DELFMA:	MOVE C,T		EXTENSION FILE
C00113 00045	ENTER ROUTINE FOR PDP11 TAPES
C00116 00046		SETZM FBMX		CLEAR CELL FOR FREE FILE NUMBER DURING COMPARE
C00119 00047	SUBR TO GET OUT DIR ENTRY NAME1, NAME2, EXT INTO EVSLOT
C00122 00048	EVCMP1:	JUMPN T,CPOPJ1		IF IN USE, RETURN
C00123 00049	ENTFIF:	MOVEI A,117		GET OUTPUT TAPE
C00126 00050		MOVEI T1,0		INDEX FOR MASTER BIT MAP
C00129 00051	EPROCS:	TLNN F,L.MFI+L.WEI+L.WFI	MULT INPUTS?
C00132 00052	SCOB:	MOVEI B,1		START AT BLK 1 (0 DONE ABOVE)
C00134 00053	RPB:	MOVE T1,ITYPEX		READ A WORD FROM CORRECT READ ROUTINE
C00135 00054	RPBTEN:	TLNN F,L.SCRI		READING FROM A SCRATCH FILE?
C00137 00055	RPBSIX:	SOSLE IHED+2		ANY LEFT IN TEMP BUFFER?
C00140 00056	RPBMAC:	SOSLE IHED+2		ANY LEFT IN TEMP BUFFER?
C00142 00057	RPBMFW:
C00144 00058	RPBFIF:	SOSLE IHED+2
C00146 00059	RPBVEN:	SOSLE IHED+2
C00149 00060	ROUTINE TO GET A BLK FROM SCRATCH FILE
C00152 00061	PPB:	MOVE T1,OTYPEX		GET OUTPUT TYPE INDEX
C00154 00062	PPBTL1:	ILDB T,B		GET A DIR BYTE
C00157 00063	PPBSIX:	SOSLE OHED+2		ROOM LEFT IN WBUF?
C00160 00064	PPBMAC:	SOSLE OHED+2		ROOM IN WBUF?
C00163 00065	PPBML2:	ADD B,[XWD 050000,0]	BACK UP A BYTE
C00165 00066	PPBFIF:	SKIPLE OHED+2		ROOM IN CURRENT BUFFER?
C00168 00067	PPBFL1:	ILDB T,B		GET A MASTER DIRECTORY BIT
C00171 00068	PPAVEN:				USE SAME TAG FOR BOTH
C00174 00069	PPBV2:	MOVE A,OBLK
C00177 00070	CLOSE ROUTINES
C00180 00071	PDP-15 FORMAT CLOSE ROUTINE
C00182 00072	CLSV1:	MOVE T,[XWD VBMAPO,WBUF]	WRITE THE MASTER BIT MAP BLK
C00185 00073	PDP6 FORMAT CLOSE ROUTINE
C00187 00074	DUMB ROUTINE TO SELECT THE CURRENT FILE TYPE.
C00189 00075	SWITCH TABLE - INDEX BY LETTER FROM A
C00191 00076	DISPATCH TABLE FOR TYPE OF TRANSFER OPERATION
C00192 00077	TRANSFER ROUTINES
C00194 00078	HERE WHEN I/O IS FROM PDP15 TAPE TO 36BIT OUTPUT
C00197 00079	REPEAT 4,<
C00198 00080	XFRFB:	MOVEM W,FTEMP
C00200 00081	PIVASC:	SETZM FITXW1		ASCII. BORROW PDP FIFTEEN ROUTINE
C00202 00082	HERE WHEN OUTPUT TAPE IS PDP FIFTEEN STYLE. INPUT MAY BE TOO?
C00204 00083	POFTE1:	MOVEI CKS,0
C00205 00084	PROFAB:	TLZ F,L.6DO
C00206 00085	POFEBB:	HRRZ T,IOPSOP
C00207 00086	HERE WHEN OUTPUT TAPE IS PDP ELEVEN STYLE. INPUT MAY BE TOO?
C00210 00087	PROVI:	PUSHJ P,RPB		GET 36 BITS
C00212 00088	XFRCD:	MOVEI CA,JOBSV6+1		OUTPUT ADDRESS AT START
C00214 00089	XFRCS:	PUSHJ P,OUTMRL		OUTPUT MAC RIM LOADER
C00216 00090	XFRDC:	MOVEI T,JOBSV6+1	6 TO TEN DMP TO SAV
C00218 00091	XECOBK:	MOVN W,CA		OUTPUT XBUF BLOCK
C00220 00092	XFRDS:	MOVEI T,JOBSV6+1	DUMP TO SBLK
C00222 00093	XESOBK:	MOVN W,CA		ROUTINE TO OUTPUT BLOCK OF SBLK
C00224 00094	OUTMRL:	MOVE CA,[XWD -MRLL,MRL]	POINTER TO LOADER
C00226 00095	XFRSC:	SETOM OCA		SBLK TO COMPRESSED
C00228 00096	XFRSD:	MOVEI CA,JOBSV6+1	FIRST ADDRESS WANTED
C00231 00097	FILE SPECIFIER INPUT ROUTINE
C00233 00098	FILS1:	MOVEM W,.DEV		SAVE DEVICE
C00234 00099	FILSS:	TRO F,R.SW		PARENS
C00236 00100	OCTIN:	MOVEI N,0
C00238 00101	SIXDOT:	PUSHJ P,SIXOUT		OUTPUT SIXBIT
C00239 00102	DATOUT:	JUMPLE A,NODATE
C00240 00103	RADIX FIFTY CONVERTER FOR PDP-11 TAPE DIRECTORIES
C00242 00104	AND THE REVERSE CONVERSION. CALL WITH 3 SIXBIT CHARS IN RH OF T,
C00244 00105	DECP4S:	CAIGE T,↑D1000
C00246 00106	DATVT:	JUMPE T,CPOPJ
C00248 00107	VENDAT:	JUMPG T,VDATE1		BLANK?
C00250 00108	MONTAB:	ASCII /-JAN--FEB--MAR--APR--MAY--JUN-/
C00252 00109	OBVCMR:	PUSHJ P,MOVRT
C00255 00110	OUTPUT WBUF TO BLOCK IN OBLK, ON DSK SCRATCH OR DTA AS APPROPRIATE
C00258 00111	WBK0:	PUSH P,A		SAVE WORK AC'S
C00260 00112	ERROR ROUTINES
C00262 00113	ERR16:	TRNE F,R.ABC		ALWAYS BAD CKSM?
C00264 00114	ERR28:	PUSH P,XBUF+3		SAVE ERROR CODE
C00266 00115	ERR41:	.EMSG <? DECTAPE SWITCH ON NON-DECTAPE INPUT DEVICE
C00268 00116	HELP:	MOVEI W,HELPM
C00272 00117	TEMPORARIES
C00274 00118	OTYPEX:	0
C00277 00119	DIRIOW:	IOWD 200,DIRECT
C00279 00120	CORIOW:	0
C00280 00121	
C00281 ENDMK
C⊗;
TITLE FILEX - GENERAL FILE TRANSFER ROUTINE - V15(4)
SUBTTL RC CLEMENTS - 19 OCT 71
VWHO==0			;WHO EDITED FILEX LAST
VMAJ==15		;MAJOR VERSION NUMBER
VMIN==0			;MINOR VERSION NUMBER
VEDIT==4		;EDIT NUMBER

LOC 137
EXP <VWHO>B2+<VMAJ>B11+<VMIN>B17+VEDIT
RELOC

;AC'S

F=0		;FLAGS
A=1		;FOUR AC'S FOR LOOKUPS, AND WORK.
B=2
C=3
D=4

T=5		;3 TEMPS
T1=6
T2=7

CA=10		;CORE ADDRESS AND COUNTS IN XFR ROUTINES
CKS=11		;CHECKSUMS IN XFR ROUTINES

N=12		;NUMBERS FOR DEC & OCT ROUTINES

W=14		;WORD SIZE DATA
CH=15		;CHARACTERS FOR TTY IO

P=17		;STACK

;I/O CHANNELS

INF==1		;INPUT TAPE
OUTF==2		;OUTPUT TAPE
SCRF==3		;DISK SCRATCH FILE
SCOF==4		;DISK SCRATCH FOR OUTPUT TAPE
UFDF==5		;UFD FOR * ON DSK


;ASSEMBLY PARAMETERS

IFNDEF	SYSPRT,<SYSPRT==155>	;PROTECTION FOR SYS: (EXCEPT *.SYS)
IFNDEF	SSSPRT,<SSSPRT==157>	;PROTECTION FOR SYS:*.SYS
;LEFT HALF FLAGS

L.DSKI==1	;INPUT DEV IS A DSK
L.DTI==2	;INPUT DEV IS A DTA
L.SCRI==4	;INPUT DTA HAS BEEN PUT ON NNNXFR.TMP
L.6DO==10	;OUTPUT FILE IS 6 DMP MODE (200 WDS PER BLK, NOT 177)
		; ALSO USED FOR PDP15 ABS FILES, PDP10 COMPRESSED+SHR
		; FOR TIGHT SPACING.
L.WFI==20	;INPUT FILE IS *
L.WEI==40	;INPUT EXT IS *
L.WFO==100	;OUTPUT FILE IS *
L.WEO==200	;OUTPUT EXT IS *
L.MFI==400	;INPUT FILE TERMINATED BY ","
L.STR1==1000	;FLAG HAVE PROCESSED AT LEAST ONE * INPUT FILE
L.DTO==2000	;OUTPUT IS TO DTA
L.DTMO==4000	;OUTPUT DTA IS MAC FORMAT
L.DTOO==10000	;OUTPUT DTA IS OLD SIX FORMAT
L.BEO==20000	;BLANK EXTENSION ON OUTPUT
L.SCRO==40000	;SCRATCH FILE FOR OUTPUT TAPE
L.DTFO==100000	;DECTAPE FIFTEEN OUTPUT
L.DTVO==200000	;DECTAPE ELEVEN OUTPUT
L.BFO==400000	;BLANK OUTPUT NAME

;RIGHT HALF FLAGS

R.EXT==1	;EXPLICIT EXTENSION TYPED
R.DOT==2	;DOT TYPED
R.TMP==R.DOT	;FOR USE AS A HANDY FLAG
R.SW==4		;PARENS, NOT SLASHES
R.UPA==10	;UPARROW (TAPEID)
R.ALL==R.DOT+R.UPA	;SYNTAX FLAG
R.OMT==R.UPA	;OUTPUT ALLOCATOR TURNAROUND. (SHARED BIT)
R.ITD==20	;INPUT TAPE DIRECTION IF NEEDED
R.LEVD==40	;THIS SYS HAS LEV D DISK SERVICE
R.GO==100	;/G IN EFFECT
R.GOS==200	;/G AND ERROR MSG ALREADY OUTPUT
R.OUT==400	;OUTPUT FILE NON-BLANK
R.OMD==1000	;1 IF OUTPUT MAC DIRECTION IS REVERSE
R.OMF==2000	;1 IF FREE BLOCK SKIPPED DURING ALLOCATION ON MACTAPE
R.JSCR==4000	;1 IF SHOULD JUNK SCRATCH FILE AT END
R.IN==10000	;1 IF ANY INPUT AT ALL
R.ABC==20000	;CURRENT INPUT FILE HAS ALWAYS BAD CHECKSUM BIT
R.LST==40000	;SOME REQUEST HAD /L
R.SYS==100000	;OUTPUT DEVICE IS SYS: OR DSK:[SYSPPN]
R.6DI==200000	;INPUT FILE IS SIX FORMAT DUMP (200W/B)
R.MFI2==400000	;MULT FILE INPUT SO DON'T REPEAT OUTPUT OPENS
EXTERN .JBFF,.JBREL

;CALLI ADDRESSES

CI.RES==0		;RESET
CI.DCH==4		;DEVCHR
CI.UTC==13		;ZERO DECTAPE
CI.DAT==14		;GET TODAY'S DATE
CI.PPN==24		;MY PROJ-PROG
CI.GET==41		;GETTAB
CI.PJO==30		;JOB NUMBER
CI.COR==11		;CORE

;TABLE OFFSETS

TYPNDT==0		;NON-DECTAPE
TYPTEN==1		;PDP10 DECTAPE
TYPSIX==2		;PDP6  DECTAPE
TYPMAC==3		;PROJ MAC DTA
TYPFIF==4		;PDP15 TAPE
TYPVEN==5		;PDP ELEVEN TAPE

;MISC PARAMETERS

DVDSK==200000		;DISK IN DEVCHR
DVDTA==100		;DTA IN DEVCHR
JOBSV6==73		;RH OF IOWD FOR PDP6 DMP FILE
.JOBSA==120		;JOBSA TO GET START ADDRESS FROM FILE
S.DSK==400000		;FTDISK IN LH OF STATES
.RBSTS==17		;WORD OF STATUS IN EXT LOOKUP
.RPABC==1B22		;ALWAYS BAD CHECKSUM BIT IN .RBSTS

DEFINE .MSG (M) <
XLIST
	MOVEI W,[ASCIZ \M\]
	PUSHJ P,MSG
	LIST
>
DEFINE .EMSG (M) <
XLIST
	TTCALL 11,0
	MOVEI W,[ASCIZ \M\]
	PUSHJ P,MSG
	LIST
>
;START OF FILEX

FILEX:	JFCL			;JUST IN CASE OF CCL ENTRY
	CALLI CI.RES		;CLEAR THE WORLD
	MOVEI F,0		;CLEAR ALL FLAGS
	MOVE P,PDP		;SET UP STACK
	SETZM IDEV		;BECAUSE OF RE-USE LOGIC
	SETZM ODEV		; ..
	SETZM	.PPPN		;CLEAR PERMANENT STUFF
	SETZM	.PPRT		;  ..
	SETZM	.PSW		;  ..
	SETZM	EOJFLG		;CLEAR FINAL PASS FLAG
	MOVE T,[17,,11]		;GET STATES FROM SYSTEM
	CALLI T,CI.GET		;GET STATES FROM SYSTEM
	  MOVEI T,0		;NO GETTAB
	MOVEM T,STATES		;SAVE IN CORE
	TLNE T,(<7B9>)		;LEVL D OR ABOVE?
	TRO F,R.LEVD		;YES.
	MOVEI	T,16		;GET MFD PPN
	GETTAB	T,
	  MOVE	T,[1,,1]	;IN CASE OF LEV.C
	MOVEM	T,MFDPPN
	MOVE	T,[1,,16]	;GET SYS PPN
	GETTAB	T,
	  MOVE	T,[1,,1]	;IN CASE OF LEV.C
	MOVEM	T,SYSPPN
	MOVEI W,[ASCIZ /
*/]
	PUSHJ P,MSG		;TYPE ASTERISK
BEG0:	PUSHJ P,FILSPC		;GET FILE FOR OUTPUT
	  JRST FILEX		;TRY AGAIN - ERROR RETURN
	MOVE T,.TSW		;OUTPUT SWITCHES
	TRNE T,SW.H		;HELP SWITCH?
	JRST HELP		;YES. GO TYPE HELP MSG
	MOVE T,.FILE		;ANY FILE SPECIFIED AT ALL?
	IOR T,.EXT		; ..
	IOR T,.DEV		;HOW ABOUT A DEVICE?
	SKIPE T			;ANYTHING?
	TRO F,R.OUT		;YES. ELSE NO OUTPUT
	SKIPN T,.DEV		;ANY DEVICE SPECIFIED?
	MOVSI T,(SIXBIT /DSK/)	;NO. USE DISK
	MOVEM T,ODEV		;SAVE OUTPUT DEVICE
	MOVE	A,T		;SEE WHICH DIRECTORY FOR THIS DEVICE
;NEXT INSTRUCTION REMOVED BY RPH 12-17-73 ***** NOT IMPLEMENTED AT STANFORD
;	DEVPPN	A,
	  CAME	T,[SIXBIT /SYS/]  ;SEE IF NAME IS "SYS:"
	CAMN	A,SYSPPN	;COMPARE WITH SYS PPN
	TRO	F,R.SYS		;SET SYS BIT
	CALLI T,CI.DCH		;GET OUT DEV CHARACTERISTICS
	JUMPE T,ERR47		;ANY SUCH THING?
	TLNE T,DVDTA		;DECTAPE?
	TLO F,L.DTO		;YES. REMEMBER IT
BEG0A:	TRNN T,1←14		;BINARY SUPPORTED?
	JRST ERR44		;NO. ERROR
	MOVS T,.FILE		;GET FILE NAME
	CAIN T,(SIXBIT /*/)	;WILD?
	TLO F,L.WFO		;YES. FLAG WILD FILE OUTPUT
	SKIPN T			;ANY NAME?
	TLO F,L.BFO		;NO. REMEMBER BLANK OUTPUT
	MOVSM T,OFILE		;SAVE NAME
	MOVS T,.EXT		;FILE EXTENSION
	CAIN T,(SIXBIT /*/)	;WILD?
	TLO F,L.WEO		;YES. FLAG WILD EXT OUTPUT
	SKIPN T			;ANY EXT?
	TLO F,L.BEO		;NO. REMEMBER BLANK OUTPUT
	MOVSM T,OEXT		;SAVE EXTENSION
	MOVE T,.TPPN		;GET PROJ PROG NUMBER IF ANY
	MOVEM T,OPPN		;SAVE IT.
	CAMN	T,SYSPPN	;COMPARE WITH SYS'S NUMBER
	TRO	F,R.SYS		;MATCH--SET SYS BIT
	MOVE T,.TPRT		;GET PROTECTION FOR OUTPUT
	MOVEM T,OPRT		;SAVE IT.
	MOVE T,.TID		;OUTPUT TAPE IDENTIFIER
	MOVEM T,OTID		; ..
	MOVE T,.TSW		;OUTPUT SWITCHES
	TRNE T,SW.G		;GO BEYOND ERRORS?
	TRO F,R.GO		;YES
	MOVEM T,OSW		;SAVE THE SWITCHES
	TRNE T,SW.TAP		;A TAPE SWITCH?
	TLNE F,L.DTO		;BUT NOT A TAPE ON OUTPUT?
	SKIPA			;NO. OK
	JRST ERR42		;YES. COMPLAIN
	TRNE T,SW.L		;SEE IF /L
	TRO F,R.LST		;YES--REMEMBER FOR END OF JOB
BEG1:	MOVSI T1,0		;SEE WHAT OUTPUT FORMAT TAPE IS, IF TAPE
	TRNE T,SW.M		;MAC FORMAT REQUESTED?
	MOVSI T1,L.DTMO		;YES.
	TRNE T,SW.O		;OLD (SIX) FORMAT REQUESTED?
	MOVSI T1,L.DTOO		;YES.
	TRNE T,SW.F		;FIFTEEN REQUESTED?
	MOVSI T1,L.DTFO		;YES
	TRNE T,SW.V		;ELEVEN TAPE REQUEST?
	MOVSI T1,L.DTVO		;YES.
	IOR F,T1		;SET FLAG IF ANY
	MOVEI T,TYPTEN		;ASSUME PDP10 TAPE
	TLNE F,L.DTOO		;OLD DECTAPE OUTPUT?
	MOVEI T,TYPSIX		;YES.
	TLNE F,L.DTMO		;MAC DECTAPE OUTPUT?
	MOVEI T,TYPMAC		;YES.
	TLNE F,L.DTFO		;FIFTEEN OUTPUT?
	MOVEI T,TYPFIF		;YES - GET TYPE INDEX
	TLNE F,L.DTVO		;ELEVEN OUTPUT?
	MOVEI T,TYPVEN		;YES
	TLNN F,L.DTO		;UNLESS NON-DECTAPE
	MOVEI T,TYPNDT		;IN WHICH CASE SAVE THAT TYPE
	MOVEM T,OTYPEX		;SAVE TYPE OF OUTPUT
	CALLI T,CI.PJO		;MAKE TEMP FILE NAME
	MOVEI N,3
SCRL1:	IDIVI T,12		;TIME-HONORED NAME MAKER
	ADDI T1,20		;DECIMAL SIXBIT OF JOB NUMBER
	LSHC T1,-6		;TO T2
	SOJG N,SCRL1		;THREE DIGITS
	HRRI T2,(SIXBIT /XFR/)	;NNNXFR.TMP IS NAME
	MOVEM T2,SCRNAM		;SAVE IT.

;NOW GET AN INPUT FILE SPECIFIER

ASKINP:	MOVE T,.BRKC		;SEE IF CORRECT FORMAT COMMAND
	CAIE T,"←"		;SEPARATOR MUST BE ONE OF THESE
	CAIN T,"="		; ..
	SKIPA			;OK
	JRST ERR22		;NO GOOD.
	SETZM .PSW		;THESE DONT CARRY OVER THE ARROW
	SETZM .PPRT		; ..
	SETZM .PPPN		; ..
	SETZM IFILE		;CLEAR INPUT FILE NAME
	SETZM IEXT		;AND EXT IN CASE NULL INPUT.
	MOVE T,.JBFF		;REMEMBER .JBFF BEFORE ANY FILES
	MOVEM T,SJFF		; FOR THE UFD BUFFER
	MOVEM T,SJFF2		; FOR THE INPUT BUFFERS
	MOVEM T,SJFF3		; FOR THE OUTPUT FILE BUFFERS
	MOVEM T,SJFF4		; FOR THE RPBSCR ROUTINE, AFTER OUT FILE
REINP:	TRZ F,R.IN		;INITIALIZE THIS FLAG
	TLZ F,L.MFI		;AND CLEAR COMMA-SEEN FLAG
	PUSHJ P,FILSPC		;GET AN INPUT FILE SPECIFIER
	  JRST FILEX		;BAD SYNTAX.
REINP1:	SKIPE	.TPRT		;CHECK FOR PROTECTION SPECIFIED
	JRST	ERR30		;YES--ERROR
	SKIPE	.TID		;CHECK FOR TAPE ID SPECIFIED
	JRST	ERR31		;YES--ERROR
	TLZ F,L.STR1		;NO STAR FILES PROCESSED YET
	MOVE T,.DEV		;ANY INPUT REQUESTED?
	IOR T,.FILE		; ..
	IOR T,.EXT
	IOR T,.TSW
	SKIPE T
	TRO F,R.IN		;YES. REMEMBER THAT
	SKIPE T,.DEV		;ANY DEVICE SPECIFIED?
	JRST ASKI1		;YES.
	SKIPN T,IDEV		;ANY PREVIOUS DEVICES?
	MOVSI T,(SIXBIT /DSK/)	;NO. FIRST TIME, DEFAULT IS DISK
ASKI1:	MOVEM T,IDEV		;STORE INPUT DEVICE
	TLZ F,L.DTI+L.DSKI	;FIND DEVICE TYPE. CLEAR OLD ONES.
	CALLI T,CI.DCH		;GET DEVICE CHAR BITS
	JUMPE T,ERR48		;ANY SUCH THING?
	TLNE T,DVDTA		;DECTAPE?
	TLO F,L.DTI		;YES.
	TLNE T,DVDSK		;DISK?
	TLO F,L.DSKI		;YES.
	TRNN T,1←14		;BINARY SUPPORTED?
	JRST ERR45		;NO. ERROR
	MOVS T,.FILE		;GET INPUT FILE NAME
	SKIPN T			;ANY IN INPUT STRING?
	MOVS T,IFILE		;NO. COPY PREVIOUS IF ANY
	SKIPN T			;ANY SPECIFIED?
	MOVEI T,(SIXBIT /*/)	;NO. ASSUME HE MEANS WILD.
	CAIN T,(SIXBIT /*/)	;IS IT WILD?
	TLO F,L.WFI		;YES. REMEMBER THAT.
	MOVSM T,IFILE		;AND SAVE IT.
	MOVS T,.EXT		;GET INPUT EXT FROM CMD STRING
	TRNE F,R.EXT		;ANY SPECIFIED?
	JRST ASKI2		;YES. USE IT EVEN IF BLANK
	MOVS T,IEXT		;GET PREVIOUS ONE
	SKIPN T			;ANY THERE?
	MOVEI T,(SIXBIT /*/)	;NO. USE WILD.
ASKI2:	CAIN T,(SIXBIT /*/)	;WILD?
	TLO F,L.WEI		;YES. REMEMBER THAT.
	MOVSM T,IEXT		;SAVE INPUT EXTENSION
	MOVE T,.TPPN		;GET INPUT P-PN
	MOVEM T,IPPN		; ..
	MOVE T,.TSW		;SWITCHES
	MOVEM T,ISW		;SAVE THEM
	TRNE T,SW.TAP		;A TAPE SWITCH?
	TLNE F,L.DTI		;BUT NOT A TAPE INPUT?
	SKIPA			;NO. OK
	JRST ERR41		;YES. COMPLAIN.
	TRNE T,SW.G		;GO SWITCH ON?
	TRO F,R.GO		;YES. REMEMBER IF FLAG AC
	MOVE T1,.BRKC		;GET BREAK CHARACTER
	CAIN T1,","		;COMMA?
	TLO F,L.MFI		;YES. MULTIPLE INPUT FILES.
	TLNE F,L.MFI+L.WEI+L.WFI	;MORE THAN ONE INPUT?
	TLNE F,L.WFO+L.WEO+L.BFO+L.BEO	;YES. MUST BE MULTIPLE OUTPUT TOO.
	SKIPA			;OK.
	JRST ERR11		;NO GOOD.
	TLNE	F,L.WEI		;MAKE SURE *S LINE UP
	TLNE	F,L.WEO+L.BEO	;INP EXT WILD
	SKIPA			;  IMPLIES OUT EXT WILD
	JRST	ERR11		;NO
	TLNE	F,L.WFI		;INP NAME WILD
	TLNE	F,L.WFO+L.BFO	;  IMPLIES OUT NAME WILD
	SKIPA			;YES
	JRST	ERR11		;NO
	TRNE T,SW.Z		;ZERO SWITCH ON INPUT?
	PUSHJ P,ERR43		;YES. NON-FATAL ERROR.
	TLNN F,L.DTI		;IS INPUT A TAPE?
	JRST ASKINX		;NO. SKIP DIRECTORY STUFF
;HERE TO READ AND LIST A DIRECTORY BLOCK
GETDIR:	MOVEI N,144		;YES. ASSUME DEC FORMAT PDP10
	TRNE T,SW.O		;OLD (SIX) TAPE?
	MOVEI N,1		;YES. DIR BLK IS 1
	TRNE T,SW.M!SW.F!SW.V	;PDP-11,PDP15 OR MAC FORMAT?
	MOVEI N,100		;YES. DIR BLK IS 100 OCTAL
	MOVEM N,DIRBKN		;SAVE NUMBER WHICH IS IN DIRECT BUFFER
	RELEAS INF,0		;CLEAR ANY PREVIOUS USE OF CHANNEL
	MOVEI A,117		;GET TAPE IN KLUDGE MODE
	MOVE B,IDEV		; ..
	MOVEI C,IHED2		; ..
	OPEN INF,A		; ..
	 JRST ERR1		;NOT THERE.
	MOVEI T,0(N)		;BLOCK NUMBER TO READ
	PUSHJ P,RBTDIR		;READ INTO DIRECTORY BUFFER
	  JRST ERR2		;ERROR READING.
ASKINX:	MOVE T,ISW		;GET INPUT SWITCHES
	MOVEI T1,TYPTEN		;GET TYPE INDEX
	TRNE T,SW.O		;OLD FORMAT?
	MOVEI T1,TYPSIX		;YES GET TYPE CODE
	TRNE T,SW.M		;MAC FORMAT?
	MOVEI T1,TYPMAC		;YES. GET TYPE CODE
	TRNE T,SW.F		;PDP15 FORMAT?
	MOVEI T1,TYPFIF		;YES
	TRNE T,SW.V		;ELEVEN SWITCH?
	MOVEI T1,TYPVEN		;YES. SET TYPE
	TLNN F,L.DTI		;THIS IS A DECTAPE, ISNT IT?
	MOVEI T1,TYPNDT		;NO. GET NOT DECTAPE CODE
	MOVEM T1,ITYPEX		;SAVE TYPE INDEX
	CAIE T1,TYPVEN		;PDP-11 TAPE?
	JRST GETDIX		;NO
	HLRZ T,DIRECT+1		;YES. PRE-PROCESS A BIT. GET PBM BLK #
	MOVEM T,PBMBKI
	HLRZ T,DIRECT+0		;GET LINK TO MFD DATA
	USETI INF,0(T)		;READ IT INTO DIRECT BUFFER
	INPUT INF,DIRIOW
	STATZ INF,740000
	  JRST ERR2
	MOVEM T,DIRBKN		;REMEMBER WHAT'S IN DIRECT
	HRRZ T,DIRECT+0		;GET UIC (PPN)
	MOVEM T,VENPPI		;SAVE IT
	HRRZ T,DIRECT+1		;GET LENGTH OF EACH ENTRY IN UFD
	MOVEM T,VWPEI		;SAVE IT FOR LATER
	HLRZ T,DIRECT+1		;FIRST BLK OF UFD
	USETI INF,0(T)		;READ IT INTO DIRECT. THIS IS REAL STUFF
	INPUT INF,DIRIOW
	STATZ INF,740000
	  JRST ERR2
	MOVEM T,DIRBKN		;REMEMBER WHAT BLK THIS IS
	MOVEM T,VDIRB1		;FIRST REAL DATA BLOCK
	HLRZ T,DIRECT
	MOVEM T,VDIRB2		;AND SECOND ONE
GETDIX:
;SEE IF WANT TO PUT TAPE ON SCRATCH FILE

SCRATQ:	SKIPN	EOJFLG		;IS THIS THE END-OF-JOB PASS?
	TLNN F,L.DTI		;INPUT A TAPE?
	JRST TYPDIQ		;NO.
	MOVE T,ISW		;GET SWITCHES
	TRNN T,SW.P+SW.Q+SW.R	;WANT QUICK MODE?
	JRST TYPDIQ		;NO. FORGET IT THEN.
	TRNN T,SW.P+SW.R	;WANT TO KEEP IT?
	TRO F,R.JSCR		;NO. REMEMBER TO FLUSH IT
SCRL2:	HRRZ T,.JBREL		;COMPUTE NUMBER OF BLOCKS TO FIT IN CORE
	HRRZ T1,.JBFF		; ..
	SUB T,T1		;SIZE OF FREE CORE
	ASH T,-7		;IN TAPE BLOCKS
	SUBI T,1		;MINUS FRAGMENT
	MOVEM T,BLKS		;SAVE NUMBER OF BLOCKS
	CAIL T,40		;SMALL NUMBER?
	JRST SCRB		;NO. USE THIS NUMBER
	MOVE T,.JBREL		;TRY FOR MORE CORE
	MOVEI T,2000(T)		;ASK FOR ANOTHER K
	CALLI T,CI.COR		; ..
	  JRST SCRB		;NOT THERE, USE WHAT WE HAVE.
	JRST SCRL2		;GOT IT. RECOMPUTE BLOCKS.
SCRB:	MOVEI T1,1101		;ASSUME TEN TAPE. READ 1101 BLKS
	MOVE T,ITYPEX		;GET TYPE OF TAPE
	CAIN T,TYPSIX		;IF SIX TAPE,
	HLRZ T1,DIRECT+0	;GET LENGTH OF USED TAPE
	CAIN T,TYPMAC		;FOR MAC, READ A LITTLE LESS TAPE
	MOVEI T1,1067		; ..
	CAIN T,TYPFIF		;PDP15 TAPE?
	MOVEI T1,1077		;YES. USE BLKS 0-1077
	CAIN T,TYPVEN		;PDP ELEVEN TAPE?
	MOVEI T1,1077		;YES. BLKS 1-1077
	CAIG T1,1101		;RANGE CHECK SIX TAPE
	CAIGE T1,1		; ..
	JRST ERR5		;NO GOOD 6 DIRECTORY
	MOVEM T1,LASTBK		;SAVE FOR LATER
SCR1:	MOVEI A,17		;GET DUMP MODE DISK FOR SCRATCH
	MOVSI B,(SIXBIT /DSK/)	; ..
	MOVEI C,0		;NO BUFFERS
	OPEN SCRF,A		;ASK FOR DISK
	  JRST ERR3		;NOT THERE.
	MOVE A,SCRNAM		;GET THE SCRATCH FILE NAME
	MOVSI B,(SIXBIT /TMP/)	;AND EXT
	SETZB C,D		; ..
	LOOKUP SCRF,A		;SEE IF FILE ALREADY THERE.
	  JRST SCRA		;NO. GOOD.
	MOVE T,ISW		;YES. SEE IF REALLY WANT NEW ONE
	TRNE T,SW.R		; ..
	JRST SCRC		;NO. WANT TO REUSE OLD ONE
	SETZB A,B		;YES. CLEAR NAME TO DELETE
	SETZB C,D		; ..
	CLOSE SCRF,0		;CLOSE FILE
	RENAME SCRF,A		;DELETE FILE
	JFCL			;IGNORE FAIL RETURN, ENTER WILL PROB FAIL

SCRA:	CLOSE SCRF,0		;CLOSE FILE FROM LOOKUP
	MOVE A,SCRNAM		;NOW WRITE SCRATCH FILE
	MOVSI B,(SIXBIT /TMP/)	; ..
	SETZB C,D		; ..
	ENTER SCRF,A		;TRY TO WRITE NEW SCRATCH FILE
	  JRST ERR4		;CAN'T. GIVE UP ON TEMP ON DSK
	MOVEI T,0		;BLOCK NUMBER 0
	PUSHJ P,READBT		;READ BLOCK TO TBUF
	  PUSHJ P,ERR39		;ERROR ON BLK 0
	OUTPUT SCRF,TIOL	;WRITE BLOCK 0 ON DISK FILE
	MOVEI B,1		;CURRENT BLOCK IS NOW BLK 1
SCRRL:	CAMLE B,LASTBK		;STILL SOME TO READ?
	JRST SCREND		;NO. DONE.
	MOVE T1,LASTBK		;SEE HOW MANY FOR THIS READ.
	ADDI T1,1		; ..
	SUB T1,B		;ALL OF REMAINING TAPE
	MOVE T,BLKS		;AMOUNT THAT FITS IN CORE
	ADD T,B			;BLK TO READ IF CAN FILL CORE
	CAMGE T,LASTBK		;WOULD THAT EXCEED TAPE?
	MOVE T1,BLKS		;YES. JUST READ ENOUGH FOR CORE.
	MOVEM T1,D		;SAVE THIS NUMBER OF BLOCKS
	MOVNS T1		;MAKE IOWD TO READ THIS
	LSH T1,31		;MINUS WORD COUNT
	HRR T1,SJFF		;ADDRESS-1
	MOVEM T1,CORIOW		;PUT IN COMMAND LIST
	USETI INF,0(B)		;SET FOR INPUT BLOCK
	INPUT INF,CORIOW		;READ TAPE
	STATZ INF,740000		;ANY ERRORS?
	PUSHJ P,ERR6		;YES. SEE IF /G
	OUTPUT SCRF,CORIOW	;NOW WRITE ON DISK
	STATZ SCRF,760000	;CHECK FOR ERRORS ON DISK
	PUSHJ P,ERR7		;ERR. SEE IF /G
	ADD B,D			;UPDATE NEXT BLOCK TO READ
	JRST SCRRL		;AND SEE IF DONE YET.

SCREND:	MTAPE INF,1		;DONE WITH DTA. REWIND IT.
	CLOSE SCRF,0		;CLOSE SCRATCH FILE
	MOVE A,SCRNAM		;NOW SET TO READ SCRATCH FILE
	MOVSI B,(SIXBIT /TMP/)	; ..
	SETZB C,D		; ..
	LOOKUP SCRF,A		;OPEN FOR READING
	  JRST ERR8		;OOPS. CAN'T
SCRC:	TLO F,L.SCRI		;FLAG READING SCRATCH FILE ON DSK
	SETOM SCRBK1		;FLAG NOT YET READING SCRF
TYPDIQ:	MOVE T,ISW		;GET INPUT SWITCHES
	TRNN T,SW.L		;YES. WANT A DIRECTORY LISTING?
	  JRST OUTASK		;NO DIRECTORY
	TRO	F,R.LST		;FLAG /L FOR LATER
	TLNN	F,L.DTI		;IS THIS A DECTAPE?
	JRST	OUTASK		;NO--SKIP THE DIRECTORY
	PUSHJ P,CRLF
	PUSHJ P,CRLF		;SPACE TO DIRECTORY ON PAPER
	MOVEI T1,DIRTEN		;ASSUME TEN FORMAT TYPER
	TRNE T,SW.M		;MAC SWITCH?
	MOVEI T1,DIRMAC		;YES. THAT ROUTINE ADDRESS
	TRNE T,SW.O		;OLD SIX FORMAT?
	MOVEI T1,DIRSIX		;YES. THAT ROUTINE ADDRESS
	TRNE T,SW.F		;PDP15 FORMAT?
	MOVEI T1,DIRFIF		;YES. THAT ROUTINE ADDR
	TRNE T,SW.V		;ELEVEN TAPE?
	MOVEI T1,DIRVEN		;YES. THAT ROUTINE
	PUSHJ P,0(T1)		;LIST THE DIRECTORY
	SKIPE	EOJFLG		;TEST FOR END-OF-JOB PASS
	JRST	EOJ1		;YES--GO BACK TO EOJ PROCESSING
	JRST OUTASK
;PDP-10 FORMAT DTA DIRECTORY LISTER

DIRTEN:	SKIPE T,DIRECT+177	;ANY TAPE ID?
	CAMN	T,[-1]		;YES--IS IT MEANINGFUL?
	JRST DIRTN1		;NO
	MOVEI W,[ASCIZ /TAPE ID: /]
	PUSHJ P,MSG
	PUSHJ P,SIXCR		;OUTPUT IT, WITH CRLF

DIRTN1:	MOVEI W,[ASCIZ /FREE: /]
	PUSHJ P,MSG
	MOVEI C,0		;LOOK FOR BLOCKS IN FILE 0
	PUSHJ P,BLKC10		;COUNT, 10 FORMAT, ANS IN T
	PUSHJ P,DECPRT		;OUTPUT BLOCKS
	MOVEI W,[ASCIZ / BLKS, /]
	PUSHJ P,MSG
	MOVEI T,0		;COUNT FILES FREE. CLEAR ANSWER
	MOVEI T1,26		;LENGTH OF DIRECTORY FILE SPACE
	SKIPN DIRECT+122(T1)	;THIS ONE BUSY?
	ADDI T,1		;NO. COUNT FREE FILE
	SOJG T1,.-2		;LOOP FOR ALL FILE SLOTS
	PUSHJ P,DECPRT		;NOW OUTPUT ANSWER
	MOVEI W,[ASCIZ / FILES
/]
	PUSHJ P,MSG		;FINISH LINE.
	MOVEI C,1		;NOW TYPE ALL FILENAMES ETC
DIRTNL:	SKIPN T,DIRECT+122(C)	;THIS FILE EXIST?
	JRST DIRTNN		;NO. SKIP IT
	PUSHJ P,SIXOUT		;YES. TYPE NAME.
	HLLZ T,DIRECT+150(C)	;GET EXTENSION
	JUMPE T,DIRTN2		;NONE.
	LSH T,-6		;PUT IN A DOT
	TLO T,<"."-40>B23	; ..
DIRTN2:	PUSHJ P,SIXOUT		;OUTPUT DIRECTORY EXTENSION
	PUSHJ P,BLKC10		;COUNT BLOCKS IN THIS FILE
	PUSHJ P,DECPR2		;OUTPUT ANSWER
	PUSHJ P,TAB		;TAB TO DATE COLUMN
	LDB A,[POINT 12,DIRECT+150(C),35]	;GET DATE.
	PUSHJ P,DATOUT		;OUTPUT DATE
	PUSHJ P,CRLF		;AND RETURN
DIRTNN:	CAIGE C,26		;DONE ALL FILES?
	AOJA C,DIRTNL		;NO. DO ANOTHER.
	JRST CRLF		;EXTRA LINE AT END
;OLD PDP6 FORMAT TAPE DIRECTORY LISTER

DIRSIX:	HLRZ T,DIRECT		;GET LAST BLOCK USED
	MOVNS T
	ADDI T,1101		;COMPUTE FREE
	PUSHJ P,DECPRT		;OUTPUT FREE BLKS
	MOVEI W,[ASCIZ /. FREE BLOCKS
/]
	PUSHJ P,MSG		;OUTPUT HEADER LINE
	HRRZ C,DIRECT		;START OF FOUR WORD BLOCKS
DIRSXL:	JUMPE C,DIRSXE		;CHECK RANGE ON INDEX
	CAIL C,175		; ..
	JRST DIRSXE		; ..
	SKIPN T,DIRECT(C)	;GET FILE NAME, IF ANY
	JRST DIRSXX		;NONE. END OF DIRECTORY
	PUSHJ P,SIXOUT		;OUTPUT NAME
	HLLZ T,DIRECT+1(C)	;GET EXTENSION
	LSH T,-6		;MAKE ROOM FOR DOT
	TLO T,<"."-40>B23	;PUT IN DOT
	PUSHJ P,SIXOUT		;OUTPUT EXTENSION
	PUSHJ P,TAB		;OVER TO DATE FIELD
	LDB A,[POINT 12,DIRECT+2(C),35]	;GET DATE
	PUSHJ P,DATOUT		;OUTPUT DATE
	PUSHJ P,CRLF		;END OF LINE
	ADDI C,4		;STEP TO NEXT NAME
	CAIGE C,200		;END OF DIRECTORY?
	JRST DIRSXL		;NO. ONWARD.
DIRSXX:	PUSHJ P,CRLF		;END OF DIRECTORY
	JRST CRLF		;SPACE UP AND RETURN

DIRSXE:	MOVEI W,[ASCIZ /? BAD FORMAT IN PDP6 DIRECTORY
/]
	JRST MSG		;OUTPUT AND RETURN
;PROJECT MAC DIRECTORY LISTER

DIRMAC:	HRRZ T,DIRECT+177	;GET TAPE ID IF ANY
	JUMPE T,DIRMC1		;SKIP THIS IF NONE
	MOVEI W,[ASCIZ /TAPE ID: /]
	PUSHJ P,MSG
	HRLZ T,DIRECT+177	;GET THE ID
	PUSHJ P,SIXCR		;OUTPUT IT WITH CRLF
DIRMC1:	MOVEI W,[ASCIZ /FREE: /]
	PUSHJ P,MSG
	MOVEI C,0		;COUNT BLOCKS IN FILE 0
	PUSHJ P,BLKCMC		;IN MAC FILE DIR
	PUSHJ P,DECPRT		;PRINT ANSWER
	MOVEI W,[ASCIZ / BLKS, /]
	PUSHJ P,MSG		;MORE HEADER
	MOVEI T,0		;CLEAR COUNT OF FREE FILES
	MOVEI T1,27*2		;LENGTH OF DIR NAME AREA
DIRM1L:	SKIPN DIRECT-2(T1)	;THIS FILE IN USE?
	SKIPE DIRECT-1(T1)	; ..
	SKIPA			;YES
	ADDI T,1		;NO. COUNT IT.
	SUBI T1,2		;CHECK NEXT ONE
	JUMPG T1,DIRM1L		;LOOP IF MORE
	PUSHJ P,DECPRT		;OUTPUT TOTAL
	MOVEI W,[ASCIZ / FILES
/]
	PUSHJ P,MSG
	MOVEI C,1		;SET TO LIST FILE NAMES
DIRMCL:	LSH C,1			;CHANGE INDEX TO OFFSET
	MOVE T,DIRECT-2(C)	;GET NAME
	TLNN T,-1		;NAME IN USE?
	JRST DIRMCN		;NO. SKIP IT.
	PUSHJ P,SIXTAB		;OUTPUT IT AND A TAB
	MOVE T,DIRECT-1(C)	;AND THE EXTENSION
	PUSHJ P,SIXTAB		;OUTPUT IT.
	LSH C,-1		;CONVERT BACK TO FILE NUMBER FOR BLK CT
	PUSHJ P,BLKCMC		;COUNT BLOCKS IN THIS FILE
	PUSH P,C		;SAVE CURRENT FILE NUMBER OVER EXTS
	PUSH P,T		;SAVE CURRENT COUNT
DIRMCC:	MOVEI T1,27*2		;PREPARE TO COUNT THROUGH FILENAMES
DIRML2:	CAMN C,DIRECT-1(T1)	;IS THIS THE EXTENSION OF PREV FILE?
	SKIPE DIRECT-2(T1)	; ..
	SKIPA			;NO
	JRST DIRMCA		;YES. GO COUNT ITS BLOCKS
	SUBI T1,2		;COUNT TO NEXT FILENAME
	JUMPG T1,DIRML2		;LOOP IF MORE
	JRST DIRMCB		;NO MORE CONTINUATIONS

DIRMCA:	MOVE C,T1		;CONTINUE FILE OFFSET
	LSH C,-1		;CONTINUE FILE NUMBER
	PUSHJ P,BLKCMC		;HOW MANY BLKS IN CONTINUATION FILE?
	ADDM T,0(P)		;ADD TO COUNT
	JRST DIRMCC		;AND SEE IF IT TURNS AROUND AGAIN

DIRMCB:	POP P,T			;RESTORE TOTAL FOR FILE AND CONTS
	POP P,C			;AND FILE NUMBER
	PUSHJ P,DECPR2		;OUTPUT NUMBER OF BLOCKS
	PUSHJ P,CRLF		;OUTPUT END OF LINE
DIRMN1:	CAIGE C,27		;COMPLETED ALL FILES?
	AOJA C,DIRMCL		;NO. BACK FOR NEXT
	PUSHJ P,CRLF		;YES. EOL.
	JRST CRLF		; ..

DIRMCN:	LSH C,-1
	JRST DIRMN1		;CONTINUE WITH FILE NUMBER
BLKCMC:	MOVE B,[POINT 5,DIRECT+56]	;BYTES IN MAC FILE DIR
	MOVEI T1,1067		;HOW FAR TO COUNT
	JRST BLKCNT		;GO COUNT THEM

BLKC10:	MOVE B,[POINT 5,DIRECT]	;BYTES IN DEC FILE DIR
	MOVEI T1,1101		;HOW MANY TO COUNT
BLKCNT:	MOVEI T,0		;INITIALIZE COUNT
BLKCL:	ILDB A,B		;GET A BYTE
	CAIN A,0(C)		;IS THIS BYTE IN THE DESIRED FILE?
	ADDI T,1		;YES. COUNT IT.
	SOJG T1,BLKCL		;LOOP TO NEXT BYTE
	POPJ P,0		;RETURN ANSWER IN T
;PDP15 DIRECTORY LISTER

DIRFIF:	MOVEI W,[ASCIZ /DIRECTORY LISTING
/]
	PUSHJ P,MSG
	MOVE A,[POINT 1,DIRECT]
	MOVEI T,0
	MOVEI B,1100
	ILDB C,A
	SKIPN C
	ADDI T,1
	SOJG B,.-3
	PUSHJ P,OCTP4S		;FREE BLOCKS
	MOVEI W,[ASCIZ / FREE BLKS
/]
	PUSHJ P,MSG
	SETZB C,T
DIRFL2:	MOVE T1,DIRECT+21(C)	;GET A FILE USE BIT
	TRNE T1,400000		;BIT ON?
	ADDI T,1		;YES. COUNT FILE IN USE
	ADDI C,2		;LOOK AT NEXT FILE
	CAIGE C,160
	JRST DIRFL2
	PUSHJ P,OCTP4S		;OUTPUT NUMBER OF FILES
	MOVEI W,[ASCIZ / USER FILES
/]
	PUSHJ P,MSG
	SETZB C,TBBLK
				;FALL INTO LOOP
DIRFL:	SKIPN T,DIRECT+20(C)
	JRST DIRFX
	PUSHJ P,TRMSIX		;CONVERT TO SIXBIT
	PUSHJ P,SIXOUT
	PUSHJ P,SPACE
	HLLZ T,DIRECT+21(C)
	PUSHJ P,TRMSIX		;CONVERT TO SIXBIT
	PUSHJ P,SIXOUT
	PUSHJ P,SPACE
	LDB T,[POINT 10,DIRECT+21(C),35]
	PUSHJ P,OCTP4S		;FIRST BLOCK OF FILE
	PUSHJ P,SPACE		;MOVE OVER
	MOVE T,C
	LSH T,-4		;FIND BIT MAP
	ADDI T,71
	CAMN T,TBBLK		;READ IT ALREADY?
	JRST DIRFL4		;YES
	MOVEM T,TBBLK		;NO. UPDATE TO THIS BLK
	PUSHJ P,READBT		;GET TAPE BLOCK
DIRFL4:	MOVE T1,C
	ANDI T1,16
	LSH T1,3		;WORDS WITHIN BLK FOR MAP
	ADDI T1,TBUF		;IN THE BUFFER
	HRLI T1,440100
	MOVEI N,1100
	MOVEI T,0
DIRFL3:	ILDB T2,T1
	SKIPE T2
	ADDI T,1		;COUNT BLOCK IN USE
	SOJG N,DIRFL3
	PUSHJ P,OCTP4S		;OUTPUT TOTAL THIS FILE
	PUSHJ P,CRLF
DIRFX:	ADDI C,2
	CAIGE C,160
	JRST DIRFL
	JRST CRLF
;PDP-11 DIRECTORY LISTER

DIRVEN:	MOVEI W,[ASCIZ /
DIRECTORY  [/]
	PUSHJ P,MSG
	LDB T,[POINT 8,VENPPI,27]
	PUSHJ P,OCTPRT
	PUSHJ P,COMMA
	LDB T,[POINT 8,VENPPI,35]
	PUSHJ P,OCTPRT
	MOVEI W,[ASCIZ /]

/]
	PUSHJ P,MSG
	SETZM VENFBN		;BORROW CELL AS COUNTER OF FREE FILES
DIRVL2:	MOVEI C,0		;START OF DIRECTORY BLOCK
DIRVL1:	MOVEI T,0		;GET FIRST HALF OF NAME
	PUSHJ P,GTVDWD		;GET THE WORD
	SKIPN T			;BLANK?
	AOS VENFBN		;YES. COUNT AS A FREE FILE
	JUMPE T,DIRVNN		;IF BLANKS, SKIP FILE
	PUSHJ P,R5VOUT		;PRINT IT
	MOVEI T,1		;SECOND HALF OF NAME
	PUSHJ P,GTVDWD		;GET THE WORD
	PUSHJ P,R5VOUT		;PRINT IT
	PUSHJ P,DOT		;SEPARATOR
	MOVEI T,2		;EXTENSION
	PUSHJ P,GTVDWD		;GET THE WORD
	PUSHJ P,R5VOUT		;PRINT IT
	MOVEI T,0		;CODE FOR THREE SPACES
	PUSHJ P,R5VOUT
	MOVEI T,6		;GET SIZE OF FILE
	PUSHJ P,GTVDWD		; ..
	PUSHJ P,DECP3S		;PRINT IT RIGHT ADJ IN 3 SPACES
	PUSHJ P,SPACE2
	MOVEI T,3
	PUSHJ P,GTVDWD		;GET THE DATE
	ANDI T,7777		;DATE FIELD
	PUSHJ P,VENDAT		;PRINT IT
	PUSHJ P,SPACE2
	MOVEI T,10		;GET THE PRIV WORD
	PUSHJ P,GTVDWD
	ANDI T,777
	PUSHJ P,PROOUT		;PRINT IN ANGLES
	PUSHJ P,CRLF
DIRVNN:	MOVE T,VWPEI		;SEE IF NEXT FILE EXISTS
	ADDI C,0(T)
	MOVE T1,C
	ADDI T1,0(T)
	CAIGE T1,377		;OFF END OF BLK?
	JRST DIRVL1		;NO. PRINT SOME MORE
	HLRZ T,DIRECT		;YES. SEE IF A LINK
	JUMPE T,DIRVNY		;IF NONE, PRINT SUMMARY
	MOVEM T,DIRBKN		;SAVE AS DIRECTORY BLOCK NUMBER
	PUSHJ P,RBTDIR		;READ THE BLK
	  JRST ERR2		;OOPS - ERROR ON DIRECTORY
	JRST DIRVL2

DIRVNY:	.MSG <
FREE BLKS:  >
	MOVE T,PBMBKI
	PUSHJ P,READBT
	  JRST ERR2
	MOVEI T1,TBUF+2
	MOVEI T,0
	MOVEI N,1100
	MOVSI T2,400000
DIRVL3:	JUMPN T2,DIRVY2
	MOVSI T2,400000
	ADDI T1,1
DIRVY2:	TDNN T2,[XWD 600000,600000]
	JRST DIRVY1
	LSH T2,-1
	JRST DIRVL3
DIRVY1:	TDNN T2,0(T1)
	ADDI T,1
	LSH T2,-1
	SOJG N,DIRVL3
	PUSHJ P,DECP4S
	.MSG <
FREE FILES: >
	MOVE T,VENFBN
	PUSHJ P,DECP4S
	JRST CRLF2
;TWO SUBRS TO GET WORD FROM PDP11 DIRECTORY.
;CALL WITH INDECES IN T AND C SUCH THAT ADDING THEM GIVES NUMBER OF
;PDP11 WORDS INTO DESIRED DIRECTORY.
GTVODW:	MOVEI T1,1(T)
	ADDI T1,0(C)
	ROT T1,-1
	MOVE T,ODIREC(T1)
	SKIPL T1
	MOVS T,ODIREC(T1)
	ANDI T,177777
	POPJ P,0

GTVDWD:	MOVEI T1,1(T)
	ADDI T1,0(C)
	ROT T1,-1
	MOVE T,DIRECT(T1)
	SKIPL T1
	MOVS T,DIRECT(T1)
	ANDI T,177777
	POPJ P,0
OUTASK:	TRNN F,R.OUT		;ANY OUTPUT REQUESTED?
	JRST EOJ		;NO. QUIT HERE.
	TRZE F,R.MFI2		;REPEATING AFTER COMMA?
	JRST SELFIL		;YES. OUTPUT ALREADY SET UP
	TLNN F,L.DTO		;IS OUTPUT A DECTAPE?
	JRST OUTASX		;NO. SKIP THIS SECTION
	TLZ F,L.DTMO+L.DTOO+L.DTFO+L.DTVO+L.SCRO	;PREPARE THESE FLAGS
	MOVE T,OSW		;GET OUTPUT FILE SWITCHES
	TRNE T,SW.O		;OLD SIX FORMAT?
	TLO F,L.DTOO		;OLD OUTPUT FILE
	TRNE T,SW.M		;MAC FORMAT?
	TLO F,L.DTMO		;MAC OUTPUT FILE
	TRNE T,SW.F		;PDP15 TAPE?
	TLO F,L.DTFO		;YES
	TRNE T,SW.V		;ELEVEN?
	TLO F,L.DTVO		;YES.
	MOVEI A,117		;GET OUTPUT TAPE IN KLUDGE MODE
	MOVE B,ODEV		; ..
	MOVEI C,0		;NO BUFFERS
OUTAS1:	OPEN OUTF,A		;TRY TO GET TAPE
	  JRST ERR9		;CAN'T GET IT?
OUTZQ:	TRNN T,SW.Z		;WANT OUTPUT ZEROED?
	JRST OUTAS2		;NO. SKIP THIS
	MOVEI T1,SW.Z		;CLEAR BIT IN SWITCH WORD
	ANDCAM T1,OSW		;SO ONLY DO THIS ONCE
	TRNN T,SW.Q		;QUICK OUTPUT?
	JRST OUTZA		;NO.
OUTZS:	MOVEI A,17		;YES. GET DSK FOR SCRATCH FILE
	MOVSI B,(SIXBIT /DSK/)	; ..
	MOVEI C,0		;NO HEADERS
	OPEN SCOF,A		;ASK FOR DSK
	  JRST ERR3		;NOT THERE?
	MOVE A,SCRNAM		;GET SCRATCH NAME
	HRRI A,(SIXBIT /XFO/)	;FOR OUTPUT
	MOVSI B,(SIXBIT /TMP/)	;TEMP EXT
	SETZB C,D
	ENTER SCOF,A		;ENTER IT FOR OUTPUT
	  JRST ERR4		;CAN'T?
	SETZM TBUF		;USE THIS BLOCK FOR SOME ZEROES
	MOVE T,[XWD TBUF,TBUF+1]
	BLT T,XBUF+177		;CLEAR IT
	MOVEI T,441		;LENGTH OF PSEUDO TAPE
	OUTPUT SCOF,TXIOL	;WRITE BLKS 0 THRU 1101
	STATZ SCOF,740000	;ERRORS?
	PUSHJ P,ERR35		;YES
	SOJG T,.-3		;WRITE WHOLE TAPE'S WORTH
	CLOSE SCOF,0		;CLOSE THE FILE
	HLLZS B			;CLEAN UP AC'S
	SETZB C,D		; ..
	LOOKUP SCOF,A		;OPEN FILE FOR UPDATING
	  JRST ERR35
	HLLZS B
	SETZB C,D
	ENTER SCOF,A		; ..
	  JRST ERR35
	TLO F,L.SCRO		;SUCCESSFUL. FLAG FOR LATER ROUTINES.

OUTZA:	TLNE F,L.DTMO+L.DTOO+L.DTFO+L.DTVO	;IS IT A PDP10 DTA?
	JRST OUTZR1		;NO. GO TO RIGHT ROUTINE
	USETI OUTF,144		;READ TEN DIRECTORY
	INPUT OUTF,ODIIOW	;TO GET ID
	SETSTS OUTF,117		;CLEAR ANY ERRORS
	SETZM ODIREC		;CLEAR THE DIRECTORY
	MOVE T,[XWD ODIREC,ODIREC+1]
	BLT T,ODIREC+176	;EXCEPT LAST WORD
	SKIPE T,OTID		;ANY REQUESTED ID?
	MOVEM T,ODIREC+177	;YES. STORE IT.
	MOVSI T,(<36B4+36B9>)
	MOVEM T,ODIREC		;ALLOCATE BLKS 1 AND 2
	MOVSI T,(36B9)
	MOVEM T,ODIREC+16	;AND 144
	HRLOI T,7		;AND 1102 ON
	MOVEM T,ODIREC+122	; ..
	MOVEI T,144		;PDP10 DIRECTORY BLOCK
OUTZX:	TLNE F,L.SCRO		;SCRATCH FILE?
	JRST OUTZY		;YES.
	USETO OUTF,0(T)		;SELECT DIRECTORY BLOCK
	OUTPUT OUTF,ODIIOW	;WRITE DIRECTORY OUT
	STATZ OUTF,740000	;ANY ERRORS?
	JRST ERR10		;YES.
OUTZZ:	JRST OUTAS2		;DONE ZEROING TAPE.

OUTZY:	USETO SCOF,1(T)		;SET TO WRITE DIR BLK
	OUTPUT SCOF,ODIIOW	;WRITE IT
	STATZ SCOF,740000	;ERRORS?
	JRST ERR29		;YES.
	JRST OUTZZ		;NO. DONE CLEARING DIRECTORY
OUTZR1:	TLNE F,L.DTVO		;ELEVEN?
	JRST OUTZRV		;YES.
	TLNE F,L.DTFO		;FIFTEEN?
	JRST OUTZRF		;YES.
	TLNE F,L.DTMO		;MAC OR SIX
	JRST OUTZR2		;MAC
	MOVE T,[XWD 1,5]	;SIX DIRECTORY. CLEAR IT IN CORE
	MOVEM T,ODIREC		;INITIAL WORD OF 6 DIRECTORY
	SETZM ODIREC+1		;CLEAR REST OF DIRECTORY AREA
	MOVE T,[XWD ODIREC+1,ODIREC+2]
	BLT T,ODIREC+177	; ..
	MOVEI T,1		;PDP6 DIRECTORY BLOCK NUMBER
	JRST OUTZX		;CHECK FOR ERRORS

OUTZRF:	PUSHJ P,CLRWBF		;CLEAR WBUF FOR BIT MAP BLOCKS
	MOVEI T,71		;FIRST MAP BLK
	MOVEM T,OBLK		; WHERE PPBBLK WANTS IT
	PUSHJ P,PPBBLK		;CLEAR A BIT MAP BLOCK
	AOS T,OBLK		;NEXT BLOCK
	CAIGE T,100		;TO DIRECTORY?
	JRST .-3		;NO. CLEAR ANOTHER
	SETZM ODIREC		;NOW THE DIRECTORY ITSELF
	MOVE T,[XWD ODIREC,ODIREC+1]	; ..
	BLT T,ODIREC+177	;CLEAR IT.
	MOVEI T,077600		;ALLOCATE THE DIRECTORY BLKS, 71-100
	MOVEM T,ODIREC+1	; ..
	MOVEI T,100		;BLOCK NUMBER TO WRITE IT IN
	JRST OUTZX		;GO WRITE IT OUT
OUTZRV:	SKIPN OPPN		;OUTPUT PPN SPECIFIED?
	JRST OUTZV0		;NO.
	HRRZ T1,OPPN		;CHECK IT FOR RANGE
	CAIE T1,0
	CAILE T1,377
	JRST ERR37		;NO GOOD
	HLRZ T,OPPN
	CAIE T,0
	CAILE T,377
	JRST ERR37
OUTZV0:	PUSHJ P,CLRWBF		;HAVE TO CLEAR FILE BIT MAPS
	MOVEI T,70
	MOVEM T,OBLK		;THEY START HERE
	PUSHJ P,PPBBLK		;CLEAR ONE
	AOS T,OBLK
	CAIGE T,100		;UP TO DATA?
	JRST .-3		;NO. CLEAR SOME MORE
	MOVE T,[XWD 101,4]	;LINK,INTERLEAVE FACTOR
	MOVEM T,WBUF		; TO OUTPUT BUFFER
	MOVE T,[XWD 104,104]	;FIRST PBM,LAST PBM
	MOVEM T,WBUF+1
	PUSHJ P,PPBBLK
	AOS OBLK		;BLK 101
	SKIPN OPPN		;OUTPUT PPN SPECIFIED?
	JRST OUTZV1		;NO. DEFAULT TO 1,1
	HLRZ T,OPPN
	LSH T,10		;OK PUT IN LEFT BYTE
	TROA T,0(T1)		;AND RIGHT BYTE
OUTZV1:	MOVEI T,401		;XWD MFD LINK,USER IDENT CODE (PPN) 1,1
	MOVEM T,WBUF
	MOVE T,[XWD 102,11]	;FIRST BLK OF UFD, WDS PER ENTRY IN UFD
	MOVEM T,WBUF+1
	PUSHJ P,PPBBLK		;WRITE BLK 101
	MOVEI T,104		;NEXT BLK TO WRITE
	MOVEM T,OBLK
	MOVE T,[XWD DAT104,WBUF]
	BLT T,WBUF+4		;COPY IN THE PBM'S INITIAL STATE
	MOVE T,[XWD 177777,177777]
	MOVEM T,WBUF+24		;THIS SEEMS TO BE IN REST OF BLK
	MOVE T,[XWD WBUF+24,WBUF+25]
	BLT T,WBUF+177		; ...
	PUSHJ P,PPBBLK		;WRITE PBM
	PUSHJ P,CLRWBF		;ZEROS IN WBUF
	SOS OBLK		;BLK 103
	PUSHJ P,PPBBLK		;CLEAR BLK 103 (2ND BLK OF UFD)
	MOVSI T,103		;UFD LINK FOR BLK 102 TO 103
	MOVEM T,ODIREC		;INTO OUTPUT DIRECTORY IMAGE
	SETZM ODIREC+1		;CLEAR THE REST OF IT
	MOVE T,[XWD ODIREC+1,ODIREC+2]
	BLT T,ODIREC+177
	MOVEI T,102		;WHERE OUTPUT DIRECTORY GOES
	JRST OUTZX		;GO WRITE IT.
DAT104:	XWD 0,1			;LINK,NUMBER OF PBM
	XWD 44,104		;WDS/MAP,1ST MAP BLK
	XWD 1,0			;BLKS 17-0,37-20
	XWD 0,177400		;BLKS 57-40,77-60
	XWD 37,0		;BLKS 117-100,137-120

OUTZR2:	USETI OUTF,100		;GET MAC DIRECTORY
	INPUT OUTF,ODIIOW	;KEEP TAPE ID WORD
	SETSTS OUTF,117		;IN CASE OF INPUT ERRORS (IGNORED)
	SETZM ODIREC		;FIRST CLEAR EVERYTHING
	MOVE T,[XWD ODIREC,ODIREC+1]
	BLT T,ODIREC+176	;CLEAR ALL BUT TAPE ID
	HRROS ODIREC+177	;ALLOCATE BLK 1070 ON
	SKIPE T,OTID		;REQUESTED TAPE ID?
	HLROM T,ODIREC+177	;YES. STORE IT.
	MOVSI T,(<36B4+36B9>)	;ALLOCATE BLOCKS 1 AND 2 AS BOOTSTRAP
	MOVEM T,ODIREC+56	; ..
	MOVSI T,(<33B4>)	;ALLOCATE BLOCK 100 AS DIRECTORY
	MOVEM T,ODIREC+67	; ..
	MOVEI T,100		;BLOCK TO WRITE IT BACK OUT ON
	JRST OUTZX

OUTAS2:	SETOM VODIB1		;PREPARE THESE BECAUSE DONT KNOW THEM YET
	SETOM VODIB2		; ..
	TLNN F,L.SCRO		;IS OUTPUT TO SCRATCH FILE?
	TLNN F,L.DTO		;NO, IS OUTPUT TO DECTAPE?
	JRST OUTASX		;NO. SKIP THIS
	MOVEI T1,144		;NOW READ OUTPUT DIRECTORY
	TLNE F,L.DTOO		;SIX TAPE?
	MOVEI T1,1		;YES. BLOCK 1
	TLNE F,L.DTMO+L.DTFO+L.DTVO ;ELEVEN, FIFTEEN OR MAC TAPE?
	MOVEI T1,100		;YES. BLOCK 100 OCTAL
	MOVEM T1,ODIBKN		;SAVE FOR MULTI-BLOCK ON ELEVEN
	USETI OUTF,0(T1)	;READ THE OUTPUT DIRECTORY
	INPUT OUTF,ODIIOW	; ..
	STATZ OUTF,740000	;ANY ERRORS?
	JRST ERR10		;YES.
OUTASX:
SELFIL:	TRNN F,R.IN		;ANYTHING WANTED?
	JRST SCOQ		;NO. QUIT.
	SETOM SRCHP		;FLAG NOT YET INTO DIRECTORY
	MOVE T,SJFF		;RECLAIM SPACE
	MOVEM T,.JBFF		; ..
	MOVEM T,SJFF2		;SET MINIMUM PER-FILE .JBFF

RESELF:	SETZM ODATE		;NO OUTPUT DATE YET.
	TLNN F,L.DTI		;DECTAPE INPUT?
	JRST SELFNT		;NO.
	MOVE T,ISW		;YES. GET INPUT SWITCHES
	TRNN T,SW.M+SW.O+SW.F+SW.V	;WHAT KIND OF DTA?
	JRST SELFT		;PDP10 DECTAPE
	TRNE T,SW.F		;PDP15 TAPE?
	JRST SELFIF		;YES
	TRNE T,SW.V		;ELEVEN?
	JRST SELFV		;YES.
	TRNN T,SW.M		;MAC OR SIX
	JRST SELFO		;SIX (OLD)
SELFM:	SKIPGE C,SRCHP		;MAC. GET DIRECTORY INDEX
	MOVEI C,0		;NONE YET
	JRST SELFMN		;ON TO NEXT ONE

SELFML:	MOVE A,DIRECT-2(C)	;GET A FILENAME
	MOVE B,DIRECT-1(C)	;AND EXTENSION
	TLNN A,-1		;FILE IN USE?
	JRST SELFMN		;NO. ON TO NEXT ONE
	CAME A,IFILE		;THIS THE ONE DESIRED?
	TLNE F,L.WFI		;OR IS IT WILD?
	SKIPA			;YES. WANT THIS.
	JRST SELFMN		;NO. ON TO NEXT ONE.
	CAME B,IEXT		;IF THE EXTENSION IS RIGHT, THAT IS.
	TLNE F,L.WEI		;OR IT'S WILD
	JRST SELFM1		;GOOD MATCH.
SELFMN:	ADDI C,2		;ON TO NEXT FILE
	CAIGE C,60		;LOOKED AT THEM ALL?
	JRST SELFML		;NO. TRY NEXT ONE.
	JRST SELFF		;YES. FAILURE ON THIS LOOKUP

SELFM1:	MOVEM C,SRCHP		;SAVE SEARCH POINTER IN CASE OF STAR
	MOVEM C,SRCHPM		;AND FOR EXTENSIONS
	JRST SELFW		;GIVE SUCCESS RETURN.
SELFO:	SKIPL C,SRCHP		;GET OFFSET INTO SIX DIRECTORY
	JRST SELFO1		; OK. USE IT.
	HRRZ C,DIRECT+0		;NONE YET. GET STARTER FROM DIRECTORY
	JRST SELFO2		;DONT INCREMENT IT
SELFO1:	ADDI C,4		;NEXT FILE PLEASE
SELFO2:	CAILE C,174		;STILL ON THE TAPE?
	JRST SELFF		;NO. FAILURE.
	MOVE A,DIRECT(C)	;YES. GET FILENAME
	JUMPE A,SELFF		;JUMP IF END OF DIRECTORY
	HLLZ B,DIRECT+1(C)	;AND EXTENSION FROM THE DIRECTORY
	HLLZ D,IEXT		;JUST HALF INPUT EXT WORD
	CAME A,IFILE		;NAME MATCH?
	TLNE F,L.WFI		;OR WILD?
	SKIPA			;YES. CHECK EXT
	JRST SELFON		;NO. ON TO NEXT.
	CAME B,D		;EXTENSION MATCH?
	TLNE F,L.WEI		;OR WILD?
	JRST SELFO3		;YES. USE THIS FILE
SELFON:	JRST SELFO1		;NO. ON TO NEXT FILE IN DIR

SELFO3:	MOVEM C,SRCHP		;SAVE THIS POSITION IN DIR
	LDB T,[POINT 12,DIRECT+2(C),35]	;GET DATE FROM DIR
	MOVEM T,ODATE		;SAVE FOR OUTPUT DATE
	TRZ F,R.6DI		;ASSUME NOT A DUMP FILE
	SKIPGE T,DIRECT+3(C)	;IS IT A DUMP FILE?
	TRO F,R.6DI		;YES. SET FLAG
	HLRES T			;SAVE LENGTH FROM WORD 3
	MOVNM T,IHED+0		; ..
	JRST SELFW		; AND GO TO SELECT FILE WIN
SELFT:	SKIPGE C,SRCHP		;POINTER INTO TEN DIRECTORY
	MOVEI C,0		;FIRST TIME IN
	JRST SELFTN		;ON TO NEXT FILE
SELFTL:	MOVE A,DIRECT+122(C)	;GET FILE NAME FROM DTA
	JUMPE A,SELFTN		;SKIP EMPTY SLOTS
	HLLZ B,DIRECT+150(C)	;AND EXTENSION FROM DTA DIR
	HLLZ D,IEXT		;HALFWORD REQUESTED EXT
	CAME A,IFILE		;DOES NAME MATCH?
	TLNE F,L.WFI		;OR IS IT WILD?
	SKIPA			;YES. CHECK EXT
	JRST SELFTN		;NO MATCH.
	CAME B,D		;EXTENSIONS MATCH?
	TLNE F,L.WEI		;OR WILD CARD?
	JRST SELFT1		;MATCH.
SELFTN:	CAIGE C,26		;CHECKED THE WHOLE DIR?
	AOJA C,SELFTL		;NO. TRY ANOTHER
	JRST SELFF		;YES. NOT THERE. GO TO FAIL

SELFT1:	MOVEM C,SRCHP		;SAVE CURRENT INDEX
	LDB T,[POINT 12,DIRECT+150(C),35]	;GET DATE
	MOVEM T,ODATE		;SAVE IT
	JRST SELFW		;AND GO TO WIN
SELFIF:	SKIPGE C,SRCHP		;FILE INDEX
	MOVEI C,16		;FIRST TIME THRU
	JRST SELFFN		;GO LOOP

SELFFL:	MOVE T,DIRECT(C)	;GET FILE ENTRY
	JUMPE T,SELFFN		;IF EMPTY, SKIP IT
	PUSHJ P,TRMSIX		;GET CORRECTED SIXBIT
	MOVE A,T		;TO RIGHT AC
	HLLZ T,DIRECT+1(C)
	PUSHJ P,TRMSIX		;TO SIXBIT
	HLLZ B,T		;TO COMPARISON AC
	HLLZ D,IEXT		;REQUESTED EXTENSION
	CAME A,IFILE		;MATCH?
	TLNE F,L.WFI		;OR WILD?
	SKIPA			;YES. MATCH
	JRST SELFFN
	CAME B,D		;EXT MATCH TOO?
	TLNE F,L.WEI		;OR WILD?
	JRST SELFF1		;YES.
SELFFN:	CAIL C,176
	JRST SELFF		;FAIL
	ADDI C,2
	JRST SELFFL		;TRY ANOTHER

SELFF1:	MOVEM C,SRCHP		;FOUND ONE. SAVE INDEX
	SETZM ODATE		;NO DATE IN FIFTEEN DTA DIRECTORY
	JRST SELFW		;TO WIN EXIT
SELFV:	SKIPGE C,SRCHP		;STARTED?
	MOVEI C,0		;NO
	JRST SELFVN		;NEXT FILE PLEASE
SELFVL:	PUSHJ P,SELFVR		;READ FILE NAME AND EXT FOR THIS INDEX
	MOVE A,VIFFIL		;GET FILE NAME
	JUMPE A,SELFVN		;NONE, SKIP IT
	HLLZ B,VIFEXT		;GET EXTENSION
	HLLZ D,IEXT		;AND REQUESTED ONE
	CAME A,IFILE		;MATCH ON FILE NAME?
	TLNE F,L.WFI		;OR WILD?
	SKIPA			;OK. CHECK EXT
	JRST SELFVN		;NO GOOD. MOVE ON
	CAME B,D
	TLNE F,L.WEI		;EXTENSION MATCH OR WILD?
	JRST SELFV1		;YES. FULL MATCH
SELFVN:	CAIGE C,↑D56		;END TEST (SHOULD COMPUTE IT)
	AOJA C,SELFVL		;MOVE ON
	JRST SELFF		;FAIL RETURN FROM SELFIL

SELFV1:	MOVEM C,SRCHP		;STORE INDEX OF DESIRED FILE
	SETZM RPAVC1		;START IN PHASE FOR RPAVEN ROUTINE
	MOVE T,IDATE		;GET INPUT DATE
	MOVEM T,ODATE		;COPY FOR OUTPUT
	JRST SELFW		;SELECT FILE WIN
SELFVR:	PUSH P,C		;SAVE INDEX
	MOVE T,VWPEI		;CONVERT TO INDEX OFFSET IN ELEVEN WORDS
	IMULI T,0(C)		;SEE IF OFF END OF BLK 1
	CAIL T,377		; ..
	JRST SVR1		;YES. TRY BLK 2
	SUB T,VWPEI		;IN BLK 1. RESET TO INDEX
	PUSH P,T		;SAVE OFFSET INTO DIR BLK
	MOVE T,VDIRB1		;ARE WE IN BLK 1 AT THE MOMENT?
SVR3:	CAMN T,DIRBKN		;IS THIS BLK IN DIRECT BUFFER
	JRST SVR2		;YES.
	MOVEM T,DIRBKN		;NO. MUST READ
	PUSHJ P,RBTDIR		;READ THE BLK TO TBUF AND DIRECT
	  JRST ERR2		;ERROR ON DIRECTORY READ
SVR2:	MOVEI C,0		;PREVENT OFFSET IN GTVDWD ROUTINE
	MOVE T,0(P)		;GET INDEX IN ELEVEN WORDS
	PUSHJ P,GTVDWD		;GET THE WORD
	PUSHJ P,R5VSIX		;MAKE SIXBIT
	HRLM T,VIFFIL		;HALF THE NAME
	AOS T,0(P)		;SECOND ELEVEN WORD
	PUSHJ P,GTVDWD		; GET IT
	PUSHJ P,R5VSIX		;CONVERT TO SIXBIT
	HRRM T,VIFFIL		;SAVE IT
	AOS T,0(P)		;AND THE EXTENSION
	PUSHJ P,GTVDWD		;GET WORD
	PUSHJ P,R5VSIX		;CONVERT TO SIXBIT
	HRLZM T,VIFEXT		;STORE IN EXT WORD
	AOS T,0(P)		;AND DATE
	PUSHJ P,GTVDWD		; ..
	PUSHJ P,DATVT		;CONVERT TO TEN FORMAT DATE
	MOVEM T,IDATE		;SAVE IT FOR LATER
	POP P,T			;REMOVE INDEX FROM STACK
	ADDI T,2		;GET FIRST BLOCK NUMBER
	PUSHJ P,GTVDWD		;FROM DIR
	MOVEM T,VENFBN		;SAVE IN CASE WANT TO READ THIS
	POP P,C			;GET THE FILE NUMBER
	POPJ P,0		;AND RETURN

SVR1:	MOVEI T,377
	IDIV T,VWPEI		;SEE HOW MANY FILES PER DIR BLK
	MOVNS T
	ADD T,0(P)		;INDEX IN FILES INTO SECOND DIR BLK
	IMUL T,VWPEI		;TOO BIG FOR BLK 2?
	CAIL T,377		; ..
	JRST ERR38		;YES
	SUB T,VWPEI		;NO. RESTORE WORD OFFSET INTO T
	PUSH P,T		;STACK IT
	MOVE T,VDIRB2		;SECOND BLOCK OF UFD DATA
	JRST SVR3		;GO READ IT.
SELFNT:	TLNE F,L.DSKI		;NON TAPE. DISK?
	TLNN F,L.WFI+L.WEI	;YES. NEED TO SEARCH UFD?
	JRST SELFNW		;NO. LOOKUP WHAT WE GOT.
	AOSE SRCHP		;STARTING UFD SEARCH THIS PASS?
	JRST SELFD1		;NO. MOVE ON.
	MOVEI B,0		;MAY NEED TO FIDDLE UP SYS PPN
	MOVE T,IDEV		;SEE IF INPUT IS DSK OR SYS
	MOVE A,T		; ..
	DEVPPN A,		;SEE WHAT PPN IS ASSOCIATED WITH IT
	  CAME T,[SIXBIT /SYS/]	;NO SUCH CALLI. IS IT SYS?
	CAMN A,SYSPPN		;IS THE PPN THE SYSTEM ONE?
	MOVE B,SYSPPN		;USE SYSTEM PPN AS NAME OF UFD
	SKIPE B			;IF ITS SYS,
	MOVEM B,IPPN		;STORE AS IF IT WERE TYPED IN.
	MOVEI A,14		;HAVE TO READ UFD
	SKIPN B			;WAS A SYSTEM DEVICE DECIDED ON?
	SKIPA B,IDEV		;NO. GET USER'S DISK-DEVICE NAME
	MOVSI B,(SIXBIT /SYS/)	;YES. READ DEVICE SYS TO GET SYS SRCH LIST
	SKIPN B			;LET'S MAKE SURE THERE'S SOMETHING THERE
	MOVSI B,'DSK'		;DEFAULT TO DSK IF NOTHING INPUT
	MOVEI C,UHED		; ..
	OPEN UFDF,A		; ..
	JRST ERR12		; NO DISK??
	SKIPN A,IPPN		;IS THE PROJPROG SPECIFIED?
	CALLI A,CI.PPN		;NO. GET MINE FROM MONITOR
	MOVSI B,(SIXBIT /UFD/)	;AND UFD EXTENSION
	MOVEI C,0
	MOVE D,MFDPPN		;IN THE MASTER FILE DIR
	LOOKUP UFDF,A		;TRY TO READ THE UFD
	  JRST ERR12		;CANT READ IT.
	INBUF UFDF,1		;ALLOCATE A BUFFER
	MOVE T,.JBFF		;AND UPDATE FREE CORE FOR FILE
	MOVEM T,SJFF2		; ..
SELFD1:	PUSHJ P,URPB		;READ A WORD FROM UFD
	  JRST SELFF		;END OF FILE. NOT THERE.
	MOVE A,W		;GET THE NAME
	PUSHJ P,URPB		;READ THE EXTENSION
	  JRST SELFF		;SHOULDNT QUIT HERE
	JUMPE A,SELFD1		;COULD BE OVER A BLOCK. SKIP 0'S
	HLLZ B,W		;GET THE EXTENSION
	HLLZ D,IEXT		;GET REQUESTED EXT
	CAME A,IFILE		;FILE NAME MATCH?
	TLNE F,L.WFI		;OR WILD CARD?
	SKIPA			;OK SO FAR
	JRST SELFD1		;NO GOOD. MOVE ON
	CAME B,[SIXBIT /TMP/]	;DSK FILE A .TMP?
	JRST SELFD2		;NO.
	TLNE F,L.WEI		;YES. ARE WE DOING .* FILES?
	JRST SELFD1		;YES. .TMP'S ARE NOT INCLUDED
				;UNLESS STATED EXPLICITLY.
SELFD2:	CAME B,D		;EXTENSION MATCH?
	TLNE F,L.WEI		;OR WILD CARD?
	JRST SELFW		;MATCH ON EXT TOO
	JRST SELFD1		;NO MATCH. LOOP

;SUBSIDIARY ROUTINE TO READ THE UFD

URPB:	SOSLE UHED+2		;ANY IN THIS BUFFER?
	JRST URPBOK		;YES.
	INPUT UFDF,0		;NO. GET ANOTHER BUFFER
	STATZ UFDF,020000		;END OF FILE?
	POPJ P,0		;YES. QUIT.
	STATZ UFDF,740000	;ERRORS?
	JRST ERR13		;YES.
URPBOK:	ILDB W,UHED+1		;OK. GET A WORD
	JRST CPOPJ1		;AND RETURN IT
SELFNW:	MOVE A,IFILE		;HERE WHEN NEITHER WILD NOR DTA
	HLLZ B,IEXT		;GET FILE AND EXT
SELFW:	MOVEM A,TIFILE		;STORE IN TEMPS
	MOVEM B,TIEXT		; ..
	MOVE T,SJFF2		;SET UP BUFFER AREA FOR FILE
	MOVEM T,.JBFF		; ..
	MOVEM T,SJFF3		;FOR BUFFERED OUTPUTS, AND
	MOVEM T,SJFF4		; FOR RPBSCR RTN IN CASE NO BUF OUT
	TLNN F,L.WFO+L.BFO	;SPECIFIED OUTPUT FILE?
	MOVE A,OFILE		;YES. GET IT.
	SKIPN A			;IF NO FILE AT ALL,
	MOVE A,IDEV		;GET INPUT DEVICE NAME FOR FILENAME
	MOVEM A,TOFILE		;STORE RESULT AWAY FOR ENTER
	TLNN F,L.WEO+L.BEO	;SPECIFIED OUTPUT EXT?
	MOVE B,OEXT		;YES. GET IT.
	MOVEM B,TOEXT		;STORE IT AWAY FOR ENTER
	SETOM IBLK		;CLEAR FLAGS FOR READ AND COPY ROUTINES
	SETZM IHED+2		;SINCE THIS IS A NEW FILE
	TRZ F,R.ABC		;FIND OUT ABOUT BAD CKSM
	TLNE F,L.SCRI		;ON SCRATCH FILE?
	JRST SELFW2		;NO LOOKUP NEEDED
	MOVE T,ITYPEX		;NOT SCRATCH. WHAT TYPE IS IT?
	CAIE T,TYPMAC		;MAC AND SIX DONT NEED LOOKUP
	CAIN T,TYPSIX		; ..
	JRST SELFW2		; ..
	CAIE T,TYPVEN		;ELEVEN TAPE?
	CAIN T,TYPFIF
	JRST SELFW2		;ELEVEN OR PDP15 TAPE
SELFW1:	MOVE D,IPPN		;NEED A LOOKUP. GET DIRECTORY
	MOVEI T,14		;READ IN BINARY
	MOVE T1,IDEV		;DEVICE NAME
	MOVEI T2,IHED		;BUFFER HEADER
	OPEN INF,T		;GET THE DEVICE
	  JRST ERR26		;CAN'T
	MOVE A,TIFILE		;SET BACK UP FOR LOOKUP
	MOVE B,TIEXT		; ..
	TLNE F,L.DSKI		;READING FROM DISK?
	TRNN F,R.LEVD		;NEW DISK ROUTINE?
	JRST SELLVC		;NO.
	MOVEI T,.RBSTS		;YES. DO EXTENDED LOOKUP
	MOVEM T,XBUF		;USE TRANSFER BUFFER, ITS FREE
	MOVEM A,XBUF+2		;NAME
	HLLZM B,XBUF+3		;EXTENSION
	MOVEM D,XBUF+1		;AND DIRECTORY
	LOOKUP INF,XBUF		;DO THE LOOKUP
	  JRST ERR28		;FILE NOT THERE?
	LDB T,[POINT 12,XBUF+4,35] ;GET THE FILE CREATION DATE
	MOVEM T,ODATE		;SAVE FOR THE ENTER
	MOVE T,XBUF+.RBSTS	;GET THE STATUS WORD
	TRNE T,.RPABC		;BAD CKSUM BIT?
	TRO F,R.ABC		;YES. REMEMBER IT
	JRST SELFW2		;LOOKUP DONE

SELLVC:	LOOKUP INF,A		;LEVEL C LOOKUP
	  JRST ERR29
	LDB T,[POINT 12,C,35]	;GET TWELVE BIT CREATION DATE
	MOVEM T,ODATE		;SAVE FOR ENTER
SELFW2:	INBUF INF,3		;ALLOCATE THE BUFFER SPACE
	MOVE T,.JBFF		;UPDATE OUTPUT SPACE DEFINER
	MOVEM T,SJFF3		; FOR BUFFERED OUTPUTS
	MOVEM T,SJFF4		; AND FOR RPBSCR IN CASE NO BUFFERED OUTS
	JRST ENTR		;AND GO FIND THE FILE.

SELFF:	TLZ F,L.WFI+L.WEI	;CLEAR WILD INPUT FLAGS
	TLZN F,L.STR1		;NO MORE STAR. WAS THERE ONE?
	JRST ERR23		;NO. THEN THERE WAS NO SUCH FILE.
	JRST EPROCS		;OK. GO TO END OF PROCESSING.
ENTR:	SETZM FOEXT		;CLEAR FORCED OUTPUT EXTENSION
	MOVE T,OSW		;GET OUTPUT SWITCHES
	TRNE T,SW.S+SW.C+SW.D+SW.E+SW.B	;SPECIFIC SWITCH?
	JRST ENTR2		;OUTPUT FORMAT SPECIFIED.
	TLNN F,L.WEO		;WILD OUTPUT EXTENSION?
	TLNN F,L.BEO		;NO. SPECIFIED EXTENSION?
	JRST ENTR2		;YES. USE SPECIFIED ONE.
	MOVE C,ISW		;UNDECLARED EXT. COMPUTE ONE.
	HLRZ A,TIEXT		;FROM INPUT AND TAPE FORMAT
	PUSHJ P,SELFTP		;WHAT IS INPUT FILE TYPE?
	CAIN T,FT.B		;BINARY?
	JRST ENTR2		;YES.
	MOVE T,OTYPEX		;ITS A CORE FILE OF SOME SORT.
	HLRZ T,ONMTAB(T)	;SELECT ON BASIS OF OUT DEVICE
	CAIE	T,(SIXBIT /SAV/)  ;IS THIS ONE SAV?
	JRST	ENTR1		;NO--USE IT
	CAIE	A,(SIXBIT /SVE/)  ;SEE IF INPUT IS SVE
	CAIN	A,(SIXBIT /LOW/)  ;OR LOW
	MOVE	T,A		;YES--PRESERVE THE ORIGINAL
ENTR1:	HRLZM T,FOEXT		;SAVE AS FORCED EXTENSION
ENTR2:	SETZM OFILEL		;CLEAR LENGTH OF OUTPUT FILE
	SETOM OBLK		;CLEAR CURRENT OUTPUT BLOCK
	SETZM OHED		;IN CASE ANYONE RELIES ON THESE
	SETZM OHED+1		; ..
	SETZM OHED+2		; ..
	MOVE T,OTYPEX		;GET TYPE OF OUTPUT FILE
	JRST @ENTRT(T)		;GO TO CORRECT ROUTINE FOR ENTER

ENTRT:	ENTNDT			;NOT DECTAPE
	ENTTEN			;10 STYLE DTA
	ENTSIX			;SIX STYLE DTA
	ENTMAC			;MAC STYLE DTA
	ENTFIF			;FIFTEEN STYLE DTA
	ENTVEN			;ELEVEN STYLE DTA

ONMTAB:	SIXBIT /SAV/
	SIXBIT /SAV/
	SIXBIT /DMP/
	SIXBIT /BIN/
	SIXBIT /ABS/
	SIXBIT /LOD/		;IS THIS RIGHT PDP11 SAVE FILE EXT?
ENTTEN:	TLNE F,L.SCRO		;SCRATCH OUTPUT FILE?
	JRST ENTTS		;YES.
ENTNDT:	MOVEI A,14		;NO KLUDGERY. JUST ENTER
	SKIPN B,ODEV		;OUTPUT DEVICE
	MOVSI B,(SIXBIT /DSK/)	;DEFAULT IS DISK
	MOVSI C,OHED		;BUFFER HEADER
	OPEN OUTF,A		;GET THE DEVICE
	  JRST ERR14		;CANT
	HLRZ A,TOEXT		;DECIDE IF SPACING SHOULD BE TIGHT
	MOVE C,OSW		;ON BASIS OF SWITCHES AND FILE EXTENSION
	PUSHJ P,SELFTP		;SEE IF ITS A KNOWN EXTENSION
	TLNE F,L.DTO		;DECTAPE OUTPUT?
	CAIN T,FT.B		;AND NOT A DULL FILE?
	SKIPA			;NO. STANDARD SPACING
	UGETF OUTF,T		;YES. TIGHT SPACING FORCED BY UGETF
	MOVE A,TOFILE		;GET OUTPUT FILE NAME
	SKIPN B,FOEXT		;USE FORCED EXTENSION, IF SET
	HLLZ B,TOEXT		;GET EXTENSION
	MOVE C,ODATE		;GET DATE
	MOVE D,OPPN		;GET PROJ PROG NUMBER
	ENTER OUTF,A		;WRITE THE FILE
	  JRST ERR46		;CANT
	MOVE T,SJFF3		;SET .JBFF TO THE RIGHT PLACE
	MOVEM T,.JBFF		; ..
	OUTBUF OUTF,3		;ALLOCATE THE BUFFER SPACE
	MOVE T,.JBFF		;GET TOP OF BUFFERS NOW
	MOVEM T,SJFF4		;AND SAVE IT FOR RPBSCR ROUTINE'S ALLOCATION
	SETOM SCRBK1		;FLAG HAVE CHANGED AVAIL CORE SO RPBSCR
				; WILL RECOMPUTE SPACE
	JRST PROCES		;GO PASS THE DATA

ENTTS:	MOVE A,TOFILE		;GET NAME
	SKIPN B,FOEXT		;AND EXT. FORCED?
	HLLZ B,TOEXT		;NO. USE SUPPLIED ONE
	MOVEI C,1		;START OF DIRECTORY INDEX
ENTTL1:	HLLZ T,ODIREC+150(C)	;GET EXT FOR FILE FROM DIR
	CAMN A,ODIREC+122(C)
	CAME B,T		;EXACT MATCH?
	SKIPA			;NO
	JRST ENTTSS		;YES. SUPERSEDE
	CAIGE C,26		;LOOKED AT THEM ALL?
	AOJA C,ENTTL1		;NO. LOOK ON.
	MOVEI C,1		;YES. NOW LOOK FOR A FREE ONE
ENTTL2:	SKIPN ODIREC+122(C)	;FILE FREE?
	JRST ENTTNW		;NEW FILE.
	CAIGE C,26		;CHECKED ALL OF THEM?
	AOJA C,ENTTL2		;NOT YET
	JRST ERR15		;YES. DIRECTORY FULL.
ENTTNW:
ENTTSS:	MOVEM C,OFILEX		;SAVE FILE INDEX
	MOVE T,[POINT 5,ODIREC+0]	;BYTES IN DIR
	MOVEI T1,0		;SOURCE OF ZEROES
	MOVEI N,1102		;COUNTER
	ILDB T2,T		;GET A BYTE
	CAIN T2,0(C)		;BELONG TO THIS FILE?
	DPB T1,T		;YES. FREE IT
	SOJG N,.-3		;LOOP FOR WHOLE TAPE.
	MOVEI N,1		;LOOK FOR A FREE BLOCK FOR FIRST.
	MOVE T,[POINT 5,ODIREC]
	ILDB T1,T		;GET A BYTE
	JUMPE T1,ENTTB		;IF FREE, GO USE IT.
	CAIGE N,1101		;LOOKED AT ALL BLOCKS?
	AOJA N,.-3		;NO. LOOK ON.
	JRST ERR15		;YES. THE TAPE'S FULL

ENTTB:	MOVEM N,OFIRBK		;SAVE OUTPUT FIRST BLOCK
	MOVEM T,OFIRBP		;AND POINTER TO IT.
	MOVEM A,ODIREC+122(C)	;STORE NAME
	HRR B,ODATE		;GET OUTPUT DATE
	MOVEM B,ODIREC+150(C)	;STORE EXT,DATE
	SETZM OHED+2		;NO WORDS LEFT IN WRT BUF
	JRST PROCES		;GO WRITE THE FILE
ENTSIX:	MOVEI A,117		;GET THE OUTPUT TAPE IN KLUDGE MODE
	MOVE B,ODEV		; ..
	MOVEI C,0		;NO BUFFERS
	OPEN OUTF,A		;REQUEST DEVICE
	  JRST ERR14		;CANT HAVE IT?
	MOVE A,TOFILE		;GET OUTPUT FILE NAME
	SKIPN B,FOEXT		;FORCED OUTPUT EXTENSION?
	HLLZ B,TOEXT		;OUTPUT EXTENSION
	HRRZ C,ODIREC+0		;POINTER INTO DIRECTORY
	JRST ENTS2A		;RANGE CHECK
ENTSL1:	SKIPN ODIREC(C)		;FREE FILE?
	JRST ENTS1		;YES. USE IT.
	CAME A,ODIREC(C)	;SUPERCEDE FILE?
	JRST ENTS2		;NO
	HLLZ D,ODIREC+1(C)	;MAYBE. CHECK EXT
	CAMN B,D		; ..
	JRST ENTS3		;YES. GO SUPERCEDE
ENTS2:	ADDI C,4		;ON TO NEXT ENTRY
ENTS2A:	CAIGE C,175		;TO END OF DIR?
	JRST ENTSL1		;ON TO ANOTHER SLOT
	JRST ERR27		;ERROR. ENTER FAILS

ENTS1:	MOVEM A,ODIREC(C)	;PUT IN NEW FILE NAME
	HLR B,ODIREC+0		;GET FILE'S FIRST BLOCK-1
	ADDI B,1		;FIRST BLOCK
	MOVEM B,ODIREC+1(C)	;TO DIRECTORY
	HRLM B,ODIREC+0		;COUNT ALLOCATED BLOCK
	SKIPN A,ODATE		;GET OUTPUT DATE, IF ANY
	CALLI A,CI.DAT		;NONE. USE TODAY.
	MOVEM A,ODIREC+2(C)	;STORE IN DIRECTORY
	SETZM ODIREC+3(C)	;NO IOWD (YET)
	MOVEM C,OFILEX		;SAVE DIRECTORY SLOT FOR LATER
	JRST PROCES		;AND GO PROCESS FILE

ENTS3:	PUSH P,C		;SAVE CURRENT SLOT OF MATCHING FILE
ENTS3L:	MOVE T,ODIREC+4(C)	;GET NEXT SLOT
	MOVEM T,ODIREC+0(C)	;COPY IT DOWN BY ONE
	CAIGE C,177		;COPIED IT ALL?
	AOJA C,ENTS3L		;NO. MORE.
	SETZM ODIREC+177	;YES. CLEAR LAST FEW WORDS
	SETZM ODIREC+176
	SETZM ODIREC+175
	SETZM ODIREC+174
	POP P,C			;GET BACK THE SLOT NUMBER
	JRST ENTSL1		;AND LOOK FOR END.
;ENTER ROUTINE FOR MAC TAPES

ENTMAC:	MOVEI A,117		;GET TAPE IN KLUDGE MODE
	MOVE B,ODEV
	MOVEI C,0		;NO BUFFERS
	OPEN OUTF,A		;GET THE DEVICE.
	  JRST ERR14		;IT WENT AWAY?
	MOVE A,TOFILE		;GET OUTPUT FILE NAME
	SKIPN B,FOEXT		;FORCED OUTPUT EXTENSION?
	MOVE B,TOEXT		;AND EXTENSION (FULL WORD)
	JUMPN B,ENTM2		;SHUFFLE WORDS IF BLANK EXT
	MOVE B,A		; ..
	MOVSI A,(SIXBIT /@/)	; ..
ENTM2:	MOVEI C,2		;FIRST FILE SLOT INDEX
ENTML1:	SKIPN ODIREC-2(C)	;THIS SLOT FREE?
	SKIPE ODIREC-1(C)	;AND EXT?
	SKIPA			;NO
	JRST ENTM1		;YES. GO USE IT.
	CAME A,ODIREC-2(C)	;NO. IS IT SAME AS NEW FILE?
	JRST ENTM3		;NO.
	CAMN B,ODIREC-1(C)	;MAYBE. CHECK EXT
	JRST ENTM4		;YES. RE-USE THE SLOT
ENTM3:	ADDI C,2		;COUNT ON TO NEXT SLOT
	CAIGE C,60		;CHECKED THEM ALL?
	JRST ENTML1		;NO. GO ON.
	JRST ERR27		;YES. NO MORE ROOM ON TAPE.

ENTM4:	ASH C,-1		;CONVERT TO FILE NUMBER
	PUSH P,C		;SAVE CURRENT INDEX
	PUSHJ P,DELFM		;DELETE ITS FILE AND EXTS
	POP P,C			;RESTORE INDEX
	ASH C,1			;BACK TO INDEX
				;AND NOW USE THIS SLOT

ENTM1:	MOVEM A,ODIREC-2(C)	;USE THIS SLOT. ENTER NAME
	MOVEM B,ODIREC-1(C)	;AND THE EXTENSION
	ASH C,-1		;CONVERT TO FILE NUMBER
	MOVEM C,OFILEX		;AND SAVE IT FOR LATER
	JRST PROCES		;GO COPY FILE.
DELFMA:	MOVE C,T		;EXTENSION FILE
	ASH C,-1		;FILE NUMBER
DELFM:	ASH C,1			;GET INDEX TO CLEAR NAMES
	SETZB N,ODIREC-2(C)	;CLEAR THIS FILE NAME, GET A ZERO AC
	SETZM ODIREC-1(C)	;CLEAR EXT TOO
	ASH C,-1		;BACK TO FILE NUMBER
	MOVEI T,1067		;LAST BLK TO LOOK AT
	MOVE T1,[POINT 5,ODIREC+56]
DELFML:	ILDB T2,T1		;GET A DIR BYTE
	CAMN T2,C		;IN THIS FILE?
	DPB N,T1		;YES. FREE IT
	SOJG T,DELFML		;RUN THRU WHOLE DIR
	MOVEI T,2		;NOW SEE IF THERES AN EXTENSION
DELFMB:	SKIPN ODIREC-2(T)	;SEE IF EXT
	CAME C,ODIREC-1(T)	;IS THE EXT = THE CURRENT FILE NO?
	SKIPA			;NOT AN EXT.
	JRST DELFMA		;AN EXT. GO DELETE IT TOO
	ADDI T,2		;ON TO NEXT ONE
	CAIL T,60		;ALL OF THEM?
	POPJ P,0		;YES.
	JRST DELFMB		;NO. MORE.
;ENTER ROUTINE FOR PDP11 TAPES

ENTVEN:	MOVEI A,117		;FIRST OPEN OUTPUT TAPE IN KLUDGE MODE
	MOVE B,ODEV
	MOVEI C,0
	OPEN OUTF,A		; ..
	  JRST ERR14		;TAPE NOT AVAIL?
	HLRZ T,TOFILE		;GET THREE CHARS OF OUT FILE NAME
	PUSHJ P,SIXR5V		;CONVERT TO R50VEN
	MOVEM T,OFIL1V		;SAVE FOR LOOKUP COMPARE RTN
	HRRZ T,TOFILE		;SECOND THREE CHARS
	PUSHJ P,SIXR5V		; ..
	MOVEM T,OFIL2V
	SKIPN T,FOEXT		;FORCED OUT EXT?
	HLLZ T,TOEXT		;NO. STANDARD ONE
	HLRZS T			;TO RH
	PUSHJ P,SIXR5V		;TO R50VEN
	MOVEM T,OEXTV		;TO TEMP STORAGE
	MOVEI T,100		;NOW GET THE PBM FROM MFD
	PUSHJ P,ROUTBT		;READ THE MFD PRIMARY BLK
	  JRST ERR40		;ERROR ON MFD
	HLRZ T,TBUF+1		;BIT MAP BLK NUMBER (USUALLY 104)
	MOVEM T,PBMBKO		;SAVE FOR RESTORING IT LATER
	HLRZ T,TBUF+0		;LINK TO REST OF MFD
	PUSHJ P,ROUTBT		;READ IT TO TEM BUF
	  JRST ERR40		;LOSS
	HRRZ T,TBUF+0		;GET USER ID CODE
	MOVEM T,VOUIC		;SAVE FOR LATER
	HRRZ T,TBUF+1		;LENGTH OF UFD ENTRIES
	MOVEM T,VWPEO		;SAVE VEN WDS PER ENTRY OUTPUT TAPE
	HLRZ T,TBUF+1		;FIRST BLK OF UFD
	MOVEM T,VODIB1		;SAVE
	PUSHJ P,ROUTBT		;AND READ TO GET LINK
	  JRST ERR40		;LOSS
	MOVEM T,ODIBKN		;SAVE AS CURRENT CONTENTS OF ODIREC
	HLRZ T,TBUF+0		;GET LINK TO SECOND BLK
	MOVEM T,VODIB2		;SAVE IT
	MOVE T,[XWD TBUF,ODIREC]
	BLT T,ODIREC+177	;COPY INTO OUTPUT DIRECTORY BUFFER
	MOVE T,PBMBKO		;NOW READ PBM MAP BLOCK
	PUSHJ P,ROUTBT		;READ PBM
	  JRST ERR40		;NO GOOD
	MOVE T,[XWD TBUF,VBMAPO]	;COPY INTO VEN BIT MAP OUTPUT
	BLT T,VBMAPO+177	; ..
	MOVEI C,1		;START COUNTER THRU VEN DIRECTORY
	MOVEM C,OFILEX		;OUTPUT FILE INDEX (1-56.)
	SETZM FBMX		;CLEAR CELL FOR FREE FILE NUMBER DURING COMPARE
EVL1:	PUSHJ P,EVCMP		;SUBR TO GET ENTRY AND CHECK IT AND MARK IF FREE
	  JRST EV1		;MATCHED. MUST DELETE OLD ENTRY
	AOS C,OFILEX		;NO MATCH. LOOK ONWARD
	CAIG C,↑D56		;END TEST (SHOULD BE COMPUTED)***
	JRST EVL1		;LOOK ON
	SKIPN C,FBMX		;NO MATCH. ANY FREE SLOTS?
	JRST ERR27		;NO. DIRECTORY FULL. LOSES.
	MOVEM C,OFILEX		;YES. STORE FREE INDEX
EV1:	PUSHJ P,EVGET		;GET THE DIRECTORY ENTRY FOR THIS INDEX
	MOVE T,OFIL1V		;COPY THE FILE ENTRY DATA. NAME1
	MOVEM T,EVSN1
	MOVE T,OFIL2V		;NAME2
	MOVEM T,EVSN2
	MOVE T,OEXTV		;EXTENSION
	MOVEM T,EVSEXT
	MOVE T,ODATE		;DATE
	PUSHJ P,DATTV		;IN ELEVEN FORMAT
	MOVEM T,EVSDAT
	SKIPN T,OPRT		;PROTECTION
	MOVEI T,233		;DEFAULT PROTECTION FOR VEN TAPES
	HRRZM T,EVSPRT		; ..
	MOVE T,OFILEX		;NOW GET THIS FILE'S BIT MAP IN ITS BLK
	SUBI T,1		;FILE 1 TO 0
	IDIVI T,7		;FILES PER PBM BLK
	ADDI T,70		;FIRST FBM BLK. SHOULD BE IN MFD!!!
	MOVEM T,FBMBLK		;BLK NUMBER
	IMULI T1,22		;OFFSET INTO BLOCK
	MOVEM T1,FBMX		;INDEX INTO FBM
	PUSHJ P,ROUTBT		;READ THE FBM BLK TO TBUF
	  JRST ERR40		;LOSS
	MOVEI T,TBUF		;NOW MAKE A BLT WORD TO COPY BITS OUT
	ADD T,FBMX		; ..
	MOVSI T,(T)		; ..
	HRRI T,FBMBUF		; ..
	BLT T,FBMBUF+21		;COPY THE BITS TO FBMBUF
	MOVSI T,-22		;CLEAR THEM IN MASTER (FILE GOING AWAY)
	MOVE T1,FBMBUF(T)	;GET SOME BITS
	ANDCAM T1,VBMAPO+2(T)	; CLEAR IN MASTER
	SETZM FBMBUF(T)		;AND IN THIS FILE
	AOBJN T,.-3		;LOOP THRU ALL BITS IN THE FBM
	JRST PROCES		;NOW PROCESS THE FILE

;LEAVE COPYING FROM SLOT TO ODIREC UNTIL CLOSE TIME.
;THEN WILL HAVE NAME, EXT, FIRST AND LAST BLK, NUMBER OF BLKS ALL
; READY TO WRITE OUT TOGETHER.
;AT CLOSE TIME, WRITE THE PBM,FBM,AND ODIREC.
;SUBR TO GET OUT DIR ENTRY NAME1, NAME2, EXT INTO EVSLOT

EVGET:	MOVE T,OFILEX		;OUTPUT FILE NUMBER, 1-56.
	IMUL T,VWPEO		;TIMES WORDS PER ENTRY
	CAILE T,377		;IN FIRST BLOCK?
	JRST EVGET2		;NO
EVGET1:	SUB T,VWPEO		;ENTRY 1 IS OFFSET 0
	PUSH P,T
	MOVE T,VODIB1		;IS THIS BLK IN ODIREC ALREADY?
EVGT2A:	CAMN T,ODIBKN		;COMPARE ODIREC'S NUMBER
	JRST EVGT1A		;ALREADY THERE. DONT READ AGAIN
	PUSHJ P,ROBTOD		;READ OUTPUT DIRECTORY
	  JRST ERR40
EVGT1A:	POP P,A
EVGETA:	MOVEM A,EVSPOS		;SAVE FOR USE AT CLOSE TIME
	MOVE T,A		;GET WORDS INTO BLK
	MOVEI C,0		;ARG TO GET ROUTINE
	PUSHJ P,GTVODW		;GET VEN OUT DIR WORD
	MOVEM T,EVSN1		;NAME ONE
	MOVEI T,1(A)		;NAME TWO OFFSET
	PUSHJ P,GTVODW		;GET FROM ODIREC
	MOVEM T,EVSN2		; ..
	MOVEI T,2(A)		;AND EXT WORD
	PUSHJ P,GTVODW		; ..
	MOVEM T,EVSEXT		;STORE
	POPJ P,0		;RETURN

EVGET2:	MOVEI T,377		;TRY SECOND BLK
	IDIV T,VWPEO		;HOW MANY FIT IN BLK 1?
	MOVNS T			;SUBTRACT THAT
	ADD T,OFILEX		;FROM INDEX
	IMUL T,VWPEO		;BACK TO WORDS
	CAILE T,377		;TOO BIG?
	JRST ERR38		;YES. LOSE.
	SUB T,VWPEO		;CONVERT DOWN 1 (FILE 1 IS IDX 0)
	PUSH P,T		;STACK ZEROTH WORD
	MOVE T,VODIB2		;GET BLK NUMBER TWO OF VEN DIR
	JRST EVGT2A		;AND GO READ IT

EVCMP:	PUSHJ P,EVGET		;GET THE ENTRY
	MOVE T,EVSN1		;COMPARE SLOT NAME 1
	CAME T,OFIL1V		;TO OUTPUT NAME 1
	JRST EVCMP1		;NOT A MATCH. SEE IF FREE
	MOVE T,EVSN2		;SAME FOR NAME PART 2
	CAME T,OFIL2V		; ..
	JRST CPOPJ1		;NO MATCH
	MOVE T,EVSEXT		;AND EXTENSION
	CAME T,OEXTV		; ..
	JRST CPOPJ1		;NO MATCH
	POPJ P,0		;MATCH. NON-SKIP RETURN
EVCMP1:	JUMPN T,CPOPJ1		;IF IN USE, RETURN
	MOVE T,OFILEX		;FREE. GET INDEX
	SKIPN FBMX		;FIRST FREE ONE?
	MOVEM T,FBMX		;YES. USE IT FOR ENTER.
	JRST CPOPJ1		;AND SKIP (DIFFERENT) RETURN

PTVODW:	ANDI T,177777		;MAKE SURE FITS IN ELEVEN WORD
	MOVEI T1,1(C)		;SKIP LINK WORD
	ROT T1,-1		;HALF WORDS ON TEN
	SKIPL T1		;WHICH HALF
	HRLM T,ODIREC(T1)	;LEFT
	SKIPGE T1
	HRRM T,ODIREC(T1)	;RIGHT
	POPJ P,0
ENTFIF:	MOVEI A,117		;GET OUTPUT TAPE
	MOVE B,ODEV
	MOVEI C,0		;IN UNBUFFERED MODE
	OPEN OUTF,A
	 JRST ERR14		;WENT AWAY?
	MOVE T,TOFILE		;GET OUTPUT FILE NAME
	PUSHJ P,TRMSIX		;CONVERT TO PDP15 FORMAT SIXBIT
	MOVE A,T
	SKIPN T,FOEXT
	MOVE T,TOEXT
	PUSHJ P,TRMSIX		;SAME FOR EXTENSION
	HLLZ B,T
	SETZB C,OBVFLG		;SEARCH FILE DIR FOR THIS FILE
				; AND CLEAR WRITE-DIRECTION FLAG FOR LATER
ENTFL1:	CAME A,ODIREC+20(C)	;FILE NAME MATCH?
	JRST ENTF1		;NO
	HLLZ T,ODIREC+21(C)	;EXT HALFWORD
	CAMN B,T		;EXT MATCH TOO?
	JRST ENTF2		;YES. SUPERSEDE THIS FILE
ENTF1:	ADDI C,2		;COUNT ON TO NEXT FILE
	CAIGE C,160		;LOOKED AT ALL?
	JRST ENTFL1		;NO. LOOK ON
	MOVEI C,0		;YES. FILE NOT THERE. FIND A FREE ONE
ENTFL2:	MOVE T,ODIREC+21(C)	;DEFINED BY BIT 18 OF EXT WD
	TRNN T,400000		;IN USE?
	JRST ENTF3		;NO. USE IT.
	ADDI C,2		;YES. LOOK ONWARD
	CAIGE C,160		;TO END OF FD?
	JRST ENTFL2		;NO. LOOK ON
	JRST ERR27		;YES. NO FREE FILES. YOU LOSE.
ENTF2:
ENTF3:	MOVEM A,ODIREC+20(C)	;STORE FILE NAME TO WRITE
	HRRI B,400000		;SET FILE SLOT IN USE BIT
	MOVEM B,ODIREC+21(C)	;STORE EXT AND BIT (NO FIRST BLK YET)
	MOVEM C,OFILEX		;STORE FILE INDEX
	MOVE T,C		;COPY IT FOR ARITHMETIC
	LSH T,-4		;CONVERT TO BLOCK NUMBER WHERE BIT MAP IS
	ADDI T,71		; ..
	MOVEM T,FBMBLK		;REMEMBER FOR ALLOCATION
	PUSHJ P,ROUTBT		;READ FROM SCOF OR OUTF TO TBUF
	  JRST ERR2		;BAD ON DIRECTORY READ
	MOVE T,[XWD TBUF,FBMBUF]	;COPY INTO ITS OWN BUFFER
	BLT T,FBMBUF+177	; ..
	MOVE T,OFILEX		;NOW FREE ANY BLOCKS IT HAS NOW
	ANDI T,16		;GET BIT GROUP IN BLK
	LSH T,3			;MAKE IT A WORD OFFSET
	MOVEM T,FBMX		;SAVE THIS INDEX
	MOVEI T1,0		;INDEX FOR MASTER BIT MAP
ENTFL3:	MOVE T2,FBMBUF(T)	;GET A WORD OF BITS OCCUPIED BY FILE
	ANDCAM T2,ODIREC(T1)	;CLEAR THEM IN MASTER
	SETZM FBMBUF(T)		;AND IN BIT MAP FOR FILE
	ADDI T1,1		;STEP
	AOBJN T,ENTFL3		;LOOP ALL SIXTEEN WORDS
	JRST PROCES		;ENTER COMPLETED. GO DO READS AND WRITES

PROCES:	MOVE T,OTYPEX		;FIRST PEEL OUT NON-36 BIT CASES
	CAIN T,TYPFIF		;OUTPUT TO PDP15 TAPE?
	JRST PROFIF		;YES. PROCESS OUTPUT FIFTEEN
	CAIN T,TYPVEN		;OUTPUT TO ELEVEN TAPE?
	JRST PROVEN		;YES. PROCESS OUT ELEVEN
				;NO. OUTPUT IS A 36 BIT MACHINE
	MOVE T,ITYPEX		;INPUT TAPE CHECK
	CAIN T,TYPFIF		;FIFTEEN TAPE INPUT?
	JRST PRIFIF		;YES. PROCESS INPUT FIFTEEN
	CAIN T,TYPVEN		;INPUT FROM ELEVEN TAPE?
	JRST PRIVEN		;YES. PROCESS 16 BIT TO 36.
				;NO. TRANSFER IS SOME KIND OF 36 TO 36 BIT MACHINE
	HLRZ A,TIEXT		;GET AN EXTENSION
	MOVE C,ISW		;AND SWITCHES
	PUSHJ P,SELFTP		;AND SELECT FILE TYPE
	MOVE B,T		;GET ANSWER
	MOVE C,OSW		;GET OUTPUT SWITCHES
	HLRZ A,FOEXT		;SEE IF THERE'S A FORCED EXTENSION
	CAIN A,(SIXBIT /BIN/)	;FOR A MAC FILE?
	TRO C,SW.S		;YES. PRETEND HE TYPED /S
	SKIPN A			;USE FORCED, IF ANY
	HLRZ A,TOEXT		;GET OUTPUT EXTENSION
	TLNE F,L.WEO		;WILD OUTPUT?
	HLRZ A,TIEXT		;YES. COPY INPUT
	PUSHJ P,SELFTP		;SELECT FILE TYPE
	TLZ F,L.6DO		;ASSUME NOT SIX DUMP
	CAIN T,FT.D		;SIX DUMP?
	TLO F,L.6DO		;YES. REMEMBER IT
	CAIE T,FT.C		;SHOULD FILE BE WRITTEN TIGHT ON TEN?
	CAIN T,FT.E		;NAMELY COMPRESSED OR EXPANDED?
	TLO F,L.6DO		;YES.
	IMULI B,5		;MAKE MORE SIGNIFICANT
	ADDI B,-5(T)		;GET OFFSET INTO TABLE FOR XFER
	PUSHJ P,@XARRAY-1(B)	;DO THE TRANSFER
				; AND CLOSE THE FILE
EPROCS:	TLNN F,L.MFI+L.WEI+L.WFI	;MULT INPUTS?
	JRST SCOQ		;NO. GO SEE IF TAPE NEEDS WRITING FM SCRATCH
	TRO F,R.MFI2		;FLAG RE-SCANNING, OUTPUT ALREADY OPEN
	TLNN F,L.WEI+L.WFI	;WILD?
	JRST REINP		;NO. COMMA. READ AGAIN.
	TLO F,L.STR1		;FLAG HAVE READ ONE * FILE
	JRST RESELF		;YES. READ ANOTHER OF THE * FILES.

SCOQ:	TLNN F,L.SCRO		;SCRATCH OUTPUT?
	JRST EOJ		;NO. ALL DONE
	CLOSE SCOF,0		;HAVE TO CLOSE FILE BEFORE READING
	RELEAS INF,0		;CLEAR THESE CHANNELS BECAUSE WILL USE
	RELEAS UFDF,0		; THEIR BUFFER AREAS FOR OUTPUTTING
	MOVE A,SCRNAM		;AND RE-OPEN IT FOR INPUT
	HRRI A,(SIXBIT /XFO/)
	MOVSI B,(SIXBIT /TMP/)
	SETZB C,D
	LOOKUP SCOF,A		;READ THE FILE
	  JRST ERR34		;NOT THERE?
SCO0:	USETI SCOF,1		;READ TAPE'S BLOCK 0
	INPUT SCOF,WIOL		;INTO WBUF
	STATZ SCOF,740000	;ERRORS?
	JRST ERR35		;YES. QUIT
	PUSHJ P,WBK0		;WRITE BLOCK 0 ON TAPE
	  JRST ERR19		;ERROR ON TAPE
SCO1:	SETSTS OUTF,117		;SWITCH TAPE TO DUMP MODE
SCOL2:	HRRZ T,.JBREL		;SEE HOW MUCH CORE IS AVAILABLE
	HRRZ T1,.JBFF
	SUB T,T1
	ASH T,-7		;IN TAPE BLKS
	SUBI T,1
	MOVEM T,BLKS		;SAVE FOR LOOP
	CAIL T,40		;ENOUGH FOR EFFICIENCY?
	JRST SCOB		;YES.
	MOVE T,.JBREL		;NO.
	MOVEI T,2000(T)		;ASK FOR ANOTHER K
	CALLI T,CI.COR		; ..
	  JRST SCOB		;CANT HAVE IT. WELL, USE WHAT YOU HAVE
	JRST SCOL2		;GOT IT. SEE IF ANY MORE NEEDED
SCOB:	MOVEI B,1		;START AT BLK 1 (0 DONE ABOVE)

SCOL:	CAMLE B,LASTOB		;ALL WRITTEN?
	JRST SCOEND		;YES.
	MOVE T1,LASTOB		;NO.
	ADDI T1,1		;LAST PLUS ONE
	SUB T1,B		;MINUS WHERE WE ARE
	MOVE T,BLKS		;SPACE WE HAVE IN CORE
	ADD T,B			;WHERE THAT WOULD LEAVE US
	CAMGE T,LASTOB		;TOO MUCH?
	MOVE T1,BLKS		;NO. GET IT ALL
	MOVEM T1,D		;SAVE
	MOVNS T1		;MINUS BLKS
	LSH T1,31		;MINUS WDS,,0
	HRR T1,SJFF		;PLACE FOR IT
	MOVEM T1,CORIOW		;TO IO LIST
	USETI SCOF,1(B)		;GET THE TAPE IMAGE BLK
	INPUT SCOF,CORIOW	; ..
	STATZ SCOF,760000	;OK?
	PUSHJ P,ERR32		;NO.
	USETO OUTF,0(B)		;WHERE TO WRITE ON TAPE
	OUTPUT OUTF,CORIOW	;DO SO.
	STATZ OUTF,760000	;OK?
	PUSHJ P,ERR33		;OOPS
	ADD B,D			;ONWARD DOWN THE TAPE
	JRST SCOL		;LOOP FOR MORE

SCOEND:	CLOSE OUTF,0		;CLOSE THE DTA
	MTAPE OUTF,1		;REWIND IT
	CLOSE SCOF,0		;FLUSH SCRATCH FILE
	SETZB A,B
	SETZB C,D		;RENAME TO 0
	RENAME SCOF,A		; ..
	JFCL
	RELEAS SCOF,0		; ..
	JRST EOJ		;ON TO END OF JOB PROCESSING
RPB:	MOVE T1,ITYPEX		;READ A WORD FROM CORRECT READ ROUTINE
	JRST @RPBT(T1)		; ..

RPBT:	RPBNDT
	RPBTEN
	RPBSIX
	RPBMAC
	RPBFIF
	RPBVEN

RPBNDT:	SOSLE IHED+2		;ANY MORE IN BUFFER?
	JRST RPBNOK		;YES. GO GET ONE
	INPUT INF,0		;NO. READ A BLOCK
	STATZ INF,740000	;ANY ERRORS?
	PUSHJ P,ERR16		;YES, UNLESS ABC OR /G
	STATZ INF,20000		;EOF?
	POPJ P,0		;YES. NON-SKIP RETURN
RPBNOK:	ILDB W,IHED+1		;GET A WORD
CPOPJ1:	AOS 0(P)		;SKIP RETURN
CPOPJ:	POPJ P,0		;RETURN
RPBTEN:	TLNN F,L.SCRI		;READING FROM A SCRATCH FILE?
	JRST RPBNDT		;NO. TREAT LIKE NON-DECTAPE
	SOSLE IHED+2		;GET ANOTHER WORD, IF ANY
	JRST RPBT1		;OK READ THE WORD
	SKIPL IBLK		;NEED A BLOCK. STARTED YET?
	JRST RPBT2		;YES. MOVE ON
	MOVE C,SRCHP		;NO. GET FIRST BLOCK THE HARD WAY
	MOVEI T,1		;FIRST BLOCK
	MOVE B,[POINT 5,DIRECT]
RPBTL1:	ILDB A,B		;GET A BYTE
	CAIN A,0(C)		;IN THIS FILE?
	JRST RPBT3		;YES.
	CAIGE T,1101		;TO EOT YET?
	AOJA T,RPBTL1		;NO. ONWARD
	POPJ P,0		;YES. ASSUME EOF, SINCE NO DATA BLKS

RPBT3:	PUSHJ P,RPBSCR		;READ THE BLOCK FOR LINK WORD
	  JRST ERR17		;ERROR ON SCRATCH FILE
	LDB T,[POINT 10,TBUF,27]	;GET FIRST WORD BYTE
	JRST RPBT4		;GO READ IT

RPBT2:	LDB T,[POINT 10,TBUF,17]	;LINK TO NEXT BLOCK
	JUMPE T,CPOPJ		;IF NONE, EOF
RPBT4:	MOVEM T,IBLK		;SAVE THIS BLOCK NUMBER
	CAILE T,1101		;CHECK FOR BAD BLOCK
	JRST ERR18		;BAD.
	PUSHJ P,RBTRBF		;READ BLK(T) INTO RBUF
	  JRST ERR17		;ERROR ON SCRATCH FILE
	LDB T,[POINT 7,RBUF,35]	;GET COUNT OF WORDS IN BLOCK
	MOVEM T,IHED+2		;SAVE FOR RPB
	JUMPE T,RPBT2		;IF NO DATA WORDS, LOOP
	MOVEI T,RBUF+0		;SKIP LINK
	MOVEM T,IHED+1		;SAVE POINTER
RPBT1:	AOS W,IHED+1		;COUNT TO DESIRED WORD
	MOVE W,0(W)		;GET THE WORD
	JRST CPOPJ1		;AND SKIP RETURN
RPBSIX:	SOSLE IHED+2		;ANY LEFT IN TEMP BUFFER?
	JRST RPBS1		;YES. GO GET IT
	SKIPL IBLK		;NEED A BLOCK. FIRST ONE?
	JRST RPBS2		;NO. ONWARD
	MOVE C,SRCHP		;YES. DROP BACK TO DIRECTORY
	HRRZ T,DIRECT+1(C)	;GET FIRST BLOCK NUMBER
	JRST RPBS3		;AND GO READ IT
RPBS2:	TRNE F,R.6DI		;DUMP FILE?
	JRST RPBS4		;YES.
	LDB T,[POINT 10,RBUF,17]	;NO. GET LINK
	JRST RPBS3		;READ THAT ONE
RPBS4:	AOS T,IBLK		;ASSUME NEXT BLOCK IF DUMP FILE
RPBS3:	JUMPE T,CPOPJ		;NO MORE IF ZERO LINK. EOF.
	MOVEM T,IBLK		;STORE CURRENT BLOCK
	CAILE T,1101		;END OF TAPE?
	JRST ERR18		;LINK OFF END. QUIT
	PUSHJ P,RBTRBF		;READ THE BLOCK
	  PUSHJ P,ERR16		;ERROR. SEE IF /G IN EFFECT
RPBS6:	LDB T,[POINT 7,RBUF,35]	;GET WORD COUNT
	TRNN F,R.6DI		;DUMP FILE?
	JRST RPBS7		;NO. USE COUNT FROM LINK
	MOVE T,IHED+0		;GET THE COUNT LEFT
	JUMPLE T,CPOPJ		;ANY LEFT?
	CAILE T,200		;OVER A BLOCK LEFT?
	MOVEI T,200		;200 WORDS THIS BLOCK
	MOVNS T			;MAKE MINUS
	ADDM T,IHED+0		;DECREMENT REMAINING QTY
	MOVNS T			;MAKE PLUS AGAIN
RPBS7:	MOVEM T,IHED+2		;STORE WORD COUNT
	JUMPE T,RPBS2		;IF NONE IN BLK, LOOP
	MOVEI T,RBUF		;ADDRESS OF BUFFER AFTER LINK
	TRNE F,R.6DI		;DUMP FILE?
	SUBI T,1		;YES. NO LINK. MORE DATA
	MOVEM T,IHED+1		;TO POINTER TO DATA
RPBS1:	AOS W,IHED+1		;COUNT POINTER
	MOVE W,0(W)		;GET DATUM
	JRST CPOPJ1		;AND SKIP RETURN
RPBMAC:	SOSLE IHED+2		;ANY LEFT IN TEMP BUFFER?
	JRST RPBM1		;YES. GO GET ONE.
RPBM0:	MOVE C,SRCHPM		;NO. GET FILE NUMBER FOR BLOCK SEARCH
	ASH C,-1		; ..
	SKIPL A,IBLK		;STARTED YET?
	JRST RPBM2		;YES. CONTINUE
	TRZ F,R.ITD		;CLEAR INPUT TAPE DIRECTION FLAG
	MOVEI A,1		;SEARCH FOR BLOCK
	MOVE B,[POINT 5,DIRECT+56]
RPBML1:	ILDB T,B		;GET A BYTE
	CAIN T,0(C)		;IN THIS FILE?
	JRST RPBM3		;YES. GO READ IT
	CAIGE A,1067		;TO EOT?
	AOJA A,RPBML1		;LOOK AT ANOTHER
	POPJ P,0		;ASSUME EOF IF NO BLKS IN FILE AT ALL

RPBM2:	MOVE B,IMACP		;CONTINUE SEARCH
	TRNE F,R.ITD		;WHICH WAY?
	JRST RPBM4N		;BACKWARDS
	JRST RPBM2N		;FORWARDS

RPBM2L:	CAILE A,1067		;TO END YET?
	JRST RPBMRV		;YES. REVERSE
	ILDB T,B		;GET A BYTE
	CAIE T,0(C)		;IN THIS FILE?
RPBM2N:	AOJA A,RPBM2L		;ON TO NEXT BYTE
	JRST RPBM3		;FOUND A BYTE IN THIS FILE.

RPBM4L:	CAIGE A,1		;STILL ON TAPE?
	JRST RPBMFW		;NO. GO FORWARD NOW
	ADD B,[XWD 050000,0]	;DECREMENT POINTER
	SKIPGE B		;OFF TOP OF WORD?
	SUB B,[XWD 430000,1]	;TO PREVIOUS WORD
	LDB T,B			;GET THE BYTE
	CAIE T,0(C)		;BELONG TO THIS FILE?
RPBM4N:	SOJA A,RPBM4L		;LOOP TO NEXT BYTE BACK
	JRST RPBM3		;FOUND A BLOCK
RPBMFW:
RPBMRV:	MOVEI A,2		;SEARCH FOR EXTENSION FILE
RPBMRL:	SKIPN DIRECT-2(A)		;NAME BLANK?
	CAME C,DIRECT-1(A)	;THIS THE EXTENSION?
	SKIPA			;NO
	JRST RPBMR1		;YES.
	ADDI A,2		;NO. TRY NEXT
	CAIGE A,60		;END OF DIR?
	JRST RPBMRL		;NO. LOOP FOR NEXT SLOT
	POPJ P,0		;NO EXTENSION. EOF.

RPBMR1:	MOVEM A,SRCHPM		;STORE SEARCH POINTER
	MOVEI A,0		;NOW LOOK FOR BLOCK FOR THIS FILE
	MOVE B,[POINT 5,DIRECT+56]
	TRCE F,R.ITD		;COMPLEMENT DIRECTION FLAG
	JRST RPBMR2		;NOW GOING FORWARD
	MOVEI A,1070		;NOW GOING REVERSE. SWITCH COUNTERS
	MOVE B,[POINT 5,DIRECT+177,4]
RPBMR2:	MOVEM A,IBLK		;STORE BLOCK NUMBER
	MOVEM B,IMACP		;AND POINTER
	JRST RPBM0		;AND CONTINUE SEARCH

RPBM3:	MOVEM A,IBLK		;SAVE FOR NEXT BLOCK
	MOVEM B,IMACP		; ..
	MOVEI T,200		;WORDS IN A BLOCK
	MOVEM T,IHED+2		; ..
	MOVEI T,RBUF-1		;POINTER TO DATA
	MOVEM T,IHED+1		; ..
	MOVEI T,0(A)		;TO BLOCK NUMBER ARG AC
	CAILE T,0		;IS BLOCK NUMBER GOOD?
	CAIL T,1070		; ..
	JRST ERR18		;NO. LOST SOMEWHERE.
	PUSHJ P,RBTRBF		;READ TO RBUF
	  PUSHJ P,ERR16		;ERROR. SEE IF /G
RPBM1:	AOS W,IHED+1		;GET WORD ADDRESS
	MOVE W,0(W)		;AND WORD
	JRST CPOPJ1		;AND SKIP RETURN
RPBFIF:	SOSLE IHED+2
	JRST RPBF1		;BUFFER HAS SOME
	TRZ F,R.TMP		;CLEAR OBVERSE COMP FLAG
	SKIPL IBLK		;READ ANY AT ALL YET?
	JRST RPBF2		;YES. GO GET LINK
	MOVE C,SRCHP		;NO. GET FIRST BLK NUMBER FROM DIR
	HRRZ T,DIRECT+1(C)	; ..
	JRST RPBF3		;USE IT
RPBF2:	HRRZ T,RBUF+177		;GET LINK TO NEXT BLOCK
	CAMGE T,IBLK		;GOING FORWARD?
	TRO F,R.TMP		;NO. FLAG NEED TO COMP DATA
	JRST RPBF3

RPBF3:	CAIN T,-1		;EOF FLAG OF MINUS 1?
	POPJ P,0		;YES. QUIT
	TRZ T,400000		;ACTIVE FLAG FROM DIRECTORY IS JUNK
	CAILE T,1077		;LEGAL PDP15 TAPE BLOCK?
	JRST ERR18		;NO.
	MOVEM T,IBLK		;SAVE IT
	PUSHJ P,RBTRBF		;READ TO RBUF
	  PUSHJ P,ERR16		;ERROR - SEE IF /G
RPBF6:	TRNE F,R.TMP		;NEED TO SHUFFLE THE DATA?
	PUSHJ P,OBVCMR		;YES. DO SO.
	MOVEI T,200		;WORD COUNT IS 128 MINUS HALF A WORD
	MOVEM T,IHED+2		;STORE IT
	JUMPE T,RPBF2		;IF ZERO, SKIP BLOCK
	MOVEI T,RBUF-1		;SET FOR PSEUDO ILDB
	MOVEM T,IHED+1
RPBF1:	AOS W,IHED+1		;NEXT WORD
	MOVE W,0(W)		;DATA WORD
	JRST CPOPJ1		;EXIT HAPPY
RPBVEN:	SOSLE IHED+2
	JRST RPBV1
	SKIPL IBLK		;STARTED YET?
	JRST RPBV2		;YES. FOLLOW LINK
	MOVE T,VENFBN		;NO. REMEMBER FBN FROM LOOKUP
	MOVEM T,IBLK		;SET IT UP IN BLK FOR INPUT
	JRST RPBV3
RPBV2:	HLRZ T,RBUF+0		;LINK TO NEXT BLOCK
	TRNE T,100000		;NEGATIVE?
	TRO T,600000		;YES EXTEND SIGN
	HRRES T			; ..
	MOVEM T,IBLK		;STORE AWAY
RPBV3:	JUMPE T,CPOPJ		;QUIT ON EOF
	MOVM T,IBLK		;GET INPUT BLOCK NUMBER BACK
	CAILE T,1077		;MAX BLK IN BIT MAP
	JRST ERR18		;OUT OF BOUNDS
	PUSHJ P,RBTRBF		;READ THE BLOCK FROM TAPE OR SCRATCH FILE
	  PUSHJ P,ERR16		;ERROR. SEE IF /G
	SKIPGE IBLK		;WHICH DIRECTION WAS READ?
	PUSHJ P,OBCVR		;BACKWARDS. SWAP DATA AROUND
	MOVMS IBLK		;MAKE SURE NOT NEGATIVE FOR NEXT RPB
	MOVEI T,377		;NUMBER OF 16 BIT WORDS TO READ
	MOVEM T,IHED+2
	MOVE T,[XWD 222200,RBUF]	;POINTER TO THEM
	MOVEM T,IHED+1
RPBV1:	ILDB W,IHED+1
	JRST CPOPJ1		;GOOD RETURN

RPAVEN:	SKIPE RPAVC1		;HAVE A BYTE LEFT?
	JRST RPAVN1		;YES
	PUSHJ P,RPBVEN		;NO. READ A HALF WORD
	  POPJ P,0		;EOF
	MOVEM W,RPAVW1		;STORE THE REMAINING HALF WORD
	LDB CH,[POINT 8,W,35]	;GET THE FIRST (RIGHT) BYTE
	SETOM RPAVC1		;FLAG ONE LEFT
	JRST CPOPJ1

RPAVN1:	LDB CH,[POINT 8,RPAVW1,27]	;SECOND (LEFT) BYTE
	SETZM RPAVC1		;NEED NEW WORD NEXT TIME
	JRST CPOPJ1		;GOOD RETURN.

OBCVEN:	MOVSI N,-100
OBCVL1:	MOVS T,TBUF(N)
	MOVNI T1,0(N)
	EXCH T,TBUF+177(T1)
	MOVSM T,TBUF(N)
	AOBJN N,OBCVL1
	POPJ P,0

OBCVR:	PUSHJ P,MOVRT
	PUSHJ P,OBCVEN
	JRST MOVTR
;ROUTINE TO GET A BLK FROM SCRATCH FILE

RPBSCR:	SKIPLE T1,SCRBK1	;STARTED COR BFR YET?
	JRST RPBSCC		;YES
	HRRZ T2,.JBREL		;NO. COMPUTE BLOCKS TO FIT
	SUB T2,SJFF4		; ..
	ASH T2,-7		; ..
	MOVEI T2,-1(T2)		; ..
	MOVEM T2,BLKS		;SAVE
RPBSCC:	CAIGE T,-1(T1)		;DESIRED BLOCK BEFORE CURRENT?
	JRST RPBSCA		;YES. MUST READ
	ADD T1,BLKS		;CHECK IF IN CORE
	CAIGE T,-1(T1)		;OFF THE TOP?
	JRST RPBSCB		;ITS IN CORE. GO GET IT
RPBSCA:	MOVE T1,BLKS		;COMPUTE WHERE TO START DSK
	ASH T1,-2		;STATISTICALLY FORWARD MOSTLY
	MOVNS T1
	ADDI T1,1(T)		;REQ-SIZ/4
	SKIPG T1		;UNLESS TOO LOW
	MOVEI T1,1		;START AT BEGINNING
	MOVEM T1,SCRBK1		;HERE'S BASE OF COR IMAGE
	USETI SCRF,0(T1)	;SET DSK TO IT
	ADD T1,BLKS		;HOW MUCH TO READ
	MOVE T2,LASTBK		;CHECK TO MAKE SURE STILL ON TAPE
	CAILE T1,1(T2)		;OFFSET BY ONE FOR BLK ZERO BEING BLK 1 OF DSK
	MOVEI T1,1(T2)		;TOO MANY. JUST READ THRU LASTBK OF TAPE
	ADDI T1,1		;NUMBER OF BLOCKS
	SUB T1,SCRBK1		; ..
	MOVNS T1		;- BLOCKS
	ASH T1,31		;(-WDS)
	HRR T1,SJFF4		;FREE CORE
	MOVEM T1,CORIOW		;IO LIST
	INPUT SCRF,CORIOW	;READ IT
	STATZ SCRF,740000	;ERRORS?
	POPJ P,0		;ERROR. FAIL RETURN
RPBSCB:	MOVEI T1,1(T)		;SEE WHERE DESIRED BLK IS IN CORE
	SUB T1,SCRBK1		;DISTANCE IN BLKS
	ASH T1,7		; IN WORDS
	ADD T1,CORIOW		;ADDRESS
	ADDI T1,1		;FOR THE IOWD OFFSET
	MOVSS T1		;FOR BLT
	HRRI T1,TBUF		;DESTINATION
	BLT T1,TBUF+177		;END OF BUFFER
	JRST CPOPJ1		;SUCCESS RETURN
PPB:	MOVE T1,OTYPEX		;GET OUTPUT TYPE INDEX
	JRST @PPBT(T1)		;DISPATCH

PPBT:	PPBNDT			;NON DECTAPE
	PPBTEN
	PPBSIX
	PPBMAC
	PPBFIF
	PPBVEN

PPBNDT:	SOSLE OHED+2		;ANY LEFT IN THIS BUFFER?
	JRST PPBNOK		;YES
	OUTPUT OUTF,0		;NO. SEND BUFFER
	STATZ OUTF,740000	;ERRORS?
	JRST ERR19		;YES. QUIT
PPBNOK:	IDPB W,OHED+1		;PLACE WORD IN BFR
	JRST CPOPJ1		;OK RETURN

PPBTEN:	TLNN F,L.SCRO		;SCRATCH OUTPUT FILE?
	JRST PPBNDT		;NO. USE SYSTEM'S IO
	SKIPLE OHED+2		;HAS BUFFER ANY SPACE?
	JRST PPBT1		;YES. USE IT
	SKIPLE OBLK		;NO. HAS I/O BEEN STARTED BEFORE?
	JRST PPBTN1		;YES. GO HANDLE END OF BLOCK
	MOVE A,OFIRBK		;NO. GET FIRST BLOCK.
	MOVE B,OFIRBP		;AND POINTER TO IT
	MOVE C,OFILEX		;FILE INDEX
	DPB C,B			;ALLOCATE THE FIRST BLOCK
	TRZ F,R.OMF+R.OMD+R.OMT	;CLEAR ALLOCATION CUES
	JRST PPBT3		;DIVE INTO ALLOCATER AT BUFFER CLR
PPBTL1:	ILDB T,B		;GET A DIR BYTE
	JUMPE T,PPBT4		;JUMP IF ITS FREE
PPBT2:	CAIGE A,1101		;TO END OF TAPE?
	AOJA A,PPBTL1		;NO. LOOK FORWARD
	JRST PPBTRV		;YES. REVERSE THE SEARCH
PPBT4:	HRRZ T,OBLK		;GET THE OUTPUT BLOCK NUMBER LAST USED
	SUB T,A			;DISTANCE TO THE FREE BLOCK
	MOVMS T			;MAGNITUDE OF DISTANCE
	TRZE F,R.OMT		;TURNAROUND IN PROGRESS?
	JRST PPBT4A		;YES. FORGET INT FACTOR FOR NOW
	TLNN F,L.6DO		;TIGHT FILE?
	JRST PPBT4B		;NO
	CAIL T,2			;YES. CLOSE ENOUGH?
	JRST PPBT4A		;YES. PUT IT THERE.
PPBT4B:	CAIGE T,4		;FOUR APART?
	JRST PPBTN		;NO.
PPBT4A:	DPB C,B			;YES. ALLOCATE THE BLK
	HRLM A,WBUF		;PUT IT IN THE LINK WORD OF PREV BLK
	MOVE T,OFIRBK		;GET THE FIRST BLOCK OF FILE
	LSH T,10		;PUT IN ITS BYTE OF LINK
	TRO T,177		;FULL BLOCK, 177 WORDS OF DATA
	HRRM T,WBUF		;PUT IN LINK WD IN BUF
	PUSHJ P,PPBBLK		;OUTPUT THE BLK TO TAPE OR SCRATCH FILE

PPBT3:	MOVEM A,OBLK		;SAVE AS NEXT BLK TO WRITE
	PUSHJ P,CLRWBF		;CLEAR WBUF FOR NEXT BLOCK
	MOVEI T,177
	MOVEM T,OHED+2		;SET UP FOR NEXT BLOCK
	MOVEI T,WBUF
	MOVEM T,OHED+1		;FIRST DATUM TO WBUF+1
PPBT1:	SOS OHED+2		;ONE LESS FREE DATUM
	AOS T,OHED+1		;WHERE TO PUT IT
	MOVEM W,0(T)		; DO SO
	JRST CPOPJ1		;SUCCESS RETURN

PPBTN:	TRO F,R.OMF		;SKIPPED A BLK
PPBTN1:	TRNN F,R.OMD		;WHICH WAY PASSING OVER DIR?
	JRST PPBT2		;FWD
	JRST PPBT6		;BACK

PPBTL2:	ADD B,[XWD 050000,0]	;BACK A BYTE
	SKIPGE B		;OFF START OF WORD?
	SUB B,[XWD 430000,1]	;YES. BACK A WORD
	LDB T,B			;GET THE BYTE
	JUMPE T,PPBT4		;JUMP IF BLK IS FREE
PPBT6:	CAILE A,1		;OFF FRONT OF TAPE?
	SOJA A,PPBTL2		;NO. TRY ANOTHER
PPBTRV:	TRZN F,R.OMF		;WORTH TURNING AROUND?
	JRST ERR20		;NO. NONE AVAIL ON TAPE
	TRC F,R.OMD		;YES. COMPLEMENT DIRECTION
	TRO F,R.OMT		;FLAG TURN-AROUND CONDITION
	JRST PPBTN1		;AND GO PICK ANOTHER BLOCK
PPBSIX:	SOSLE OHED+2		;ROOM LEFT IN WBUF?
	JRST PPBS1		;YES.
	SKIPLE OBLK		;NO. NEED A BLOCK. STARTED YET?
	JRST PPBS2		;YES. CONTINUE.
	MOVE C,OFILEX		;NO. GET FIRST BLOCK, SET UP BEFORE
	HRRZ A,ODIREC+1(C)	;FROM THE DIRECTORY SLOT
	MOVEM A,OBLK		;STORE THAT
	JRST PPBS3		;AND GO START WRITING IT

PPBS2:	HRRZ A,OHED+2		;GET COUNT
	MOVNS A
	ADDI A,177		;WORDS USED
	TLNE F,L.6DO		;DUMP OUTPUT?
	ADDI A,1		;YES. ANOTHER WORD (NO LINK)
	ADDM A,OFILEL		;ADD TO LENGTH FOR LATER UPDATE OF DIR
	HLRZ B,ODIREC+0		;LAST USED BLOCK
	ADDI B,1		;COUNT IT
	HRLM B,ODIREC+0		;NOW USED ANOTHER
	HRLM B,A		;MAKE LINK WORD
	TLNN F,L.6DO		;UNLESS DUMP FILE,
	MOVEM A,WBUF		;PUT IN LINK WORD OF THIS BLOCK
	PUSHJ P,PPBBLK		;OUTPUT BLK ON TAPE OR DSK SCRATCH
	CAILE B,1101		;STILL ON THE TAPE?
	JRST ERR20		;NO. EXCEEDED TAPE CAPACITY
	MOVEM B,OBLK		;NEW OUTPUT BLOCK

PPBS3:	MOVEI A,200		;SIZE OF BLOCK
	TLNN F,L.6DO		;UNLESS NOT DUMP,
	MOVEI A,177		;SIZE OF NON-DUMP BLOCK
	MOVEM A,OHED+2		;STORE FOR COUNTDOWN
	MOVEI A,WBUF-1		;OUTPUT POINTER WORD
	TLNN F,L.6DO		;DUMP FILE?
	MOVEI A,WBUF+0		;LEAVE SPACE FOR LINK
	MOVEM A,OHED+1		;STORE AS POINTER
	PUSHJ P,CLRWBF		;CLEAR WBUF FOR NEXT BLK
PPBS1:	AOS T,OHED+1		;COUNT OUTPUT POINTER
	MOVEM W,0(T)		;STORE DATUM
	JRST CPOPJ1		;AND RETURN
PPBMAC:	SOSLE OHED+2		;ROOM IN WBUF?
	JRST PPBM1		;YES.
	SKIPLE OBLK		;NEED A BLOCK. STARTED?
	JRST PPBM2		;YES. CONTINUE.
	MOVEI A,1		;NO. SEARCH FOR A FREE BLOCK
	MOVE B,[POINT 5,ODIREC+56]
	TRZ F,R.OMD+R.OMF+R.OMT	;INITIALIZE OUTPUT FLAGS
PPBM4:	MOVE C,OFILEX		;GET FILE INDEX
PPBML1:	ILDB T,B		;GET A BLOCK BYTE
	JUMPE T,PPBM3		;IF FREE, GO CONSIDER IT
PPBM5:	CAIGE A,1067		;END OF TAPE?
	AOJA A,PPBML1		;NO. LOOK FURTHER
	JRST PPBMRV		;NOW GO REVERSE IF ANY

PPBM3:	HRRZ T,OBLK		;CHECK FOR SPACING
	SUB T,A			;FROM PRV TO CURRENT BLK
	MOVMS T			;MAGNITUDE OF DISTANCE
	TRZE F,R.OMT		;TURNAROUND COND?
	JRST PPBM3A		;YES. IGNORE SPACING COND
	CAIGE T,4		;FOUR BLOCKS?
	JRST PPBMN		;NO. SKIP THIS ONE
PPBM3A:	DPB C,B			;ALLOCATE THIS BLOCK
	MOVEM A,OBLK		;STORE BLOCK NUMBER
	MOVEM B,OMACP		;AND BYTE POINTER
	MOVEI T,200		;SIZE OF BLOCK
	MOVEM T,OHED+2		;FOR SOSLE
	MOVEI T,WBUF-1		;AND DATA ADDRESS
	MOVEM T,OHED+1		; ..
	PUSHJ P,CLRWBF		;CLEAR THE BUFFER

PPBM1:	AOS T,OHED+1		;WRITE THE WORD VIA POINTER
	MOVEM W,0(T)		; INTO BUFFER
	JRST CPOPJ1		;AND SKIP RETURN

PPBM2:	PUSHJ P,PPBBLK		;OUTPUT BLK ON TAPE OR DSK SCRATCH
	MOVE C,OFILEX		;GET THE CURRENT FILE NUMBER
	MOVE A,OBLK		;GET OUTPUT BLOCK
	SKIPA B,OMACP		;AND BYTE POINTER TO DIRECTORY
PPBMN:	TRO F,R.OMF		;SKIPPING A BLOCK. REMEMBER THAT
PPBMN1:	TRNN F,R.OMD		;WHICH WAY WE GOING?
	JRST PPBM5		;FORWARD. GET NEXT FREE BLOCK
	JRST PPBM6		;BACKWARD. GET NEXT FREE BLK
PPBML2:	ADD B,[XWD 050000,0]	;BACK UP A BYTE
	SKIPGE B		;OUT OF WORD?
	SUB B,[XWD 430000,1]	;YES RIGHT 35 BITS, BACK A WORD
	LDB T,B			;GET THIS BYTE
	JUMPE T,PPBM3		;IF FREE, CONSIDER IT
PPBM6:	CAILE A,1		;NOT FREE. AT FRONT?
	SOJA A,PPBML2		;NO. LOOK ON.
	JRST PPBMFW		;YES. TURN AROUND AGAIN

PPBMRV:
PPBMFW:	TRZN F,R.OMF		;DID WE PASS ANY BLOCKS?
	JRST ERR20		;NO. TAPE FULL
	MOVEI C,2		;YES. LOOK FOR A FILE FOR EXT.
PPBMRL:	SKIPN ODIREC-2(C)	;THIS ONE FREE?
	SKIPE ODIREC-1(C)	; ..
	SKIPA			;NO.
	JRST PPBMR1		;YES. GO USE IT.
	CAIL C,60		;LOOKED AT ALL?
	JRST ERR20		;YES. GIVE UP.
	ADDI C,2		;NO. ONWARD
	JRST PPBMRL		; ..

PPBMR1:	MOVE T,C		;COPY OF FILE INDEX
	ASH C,-1		;CONVERT TO FILE NUMBER
	EXCH C,OFILEX		;SAVE OUTPUT FILE INDEX, GET OLD ONE
	MOVEM C,ODIREC-1(T)	;MARK EXTENSION IN NEW SLOT
	TRC F,R.OMD		;TURN AROUND
	MOVE C,OFILEX		;GET NEW FILE INDEX
	TRO F,R.OMT		;REMEMBER TURNAROUND COND
	JRST PPBMN1		;AND ON TO NEXT BLOCK
PPBFIF:	SKIPLE OHED+2		;ROOM IN CURRENT BUFFER?
	JRST PPBF1		;YES - USE IT
	SKIPL OBLK		;NEED A BLK. FIRST TIME IN?
	JRST PPBF2		;NO.
	MOVEI A,1		;YES. SEARCH FOR A BLK
	MOVE B,[POINT 1,ODIREC,0]
	ILDB T,B		;GET A BIT
	JUMPE T,PPBF3		;IS IT FREE?
	CAIGE A,1077		;NO. TO END OF TAPE?
	AOJA A,.-3		;LOOP
	JRST ERR20		;TAPE FULL.

PPBF3:	MOVE C,OFILEX		;GET FILE INDEX
	DPB A,[POINT 10,ODIREC+21(C),35]
	MOVEI T,1		;ALLOCATE IN MASTER DIR
	DPB T,B
	MOVE T1,B		;AND IN OWN BIT MAP
	ADDI T1,FBMBUF-ODIREC	;MOVE TO OTHER BLOCK
	ADD T1,FBMX		;AND TO SUBGROUP IN BLK
	DPB T,T1		;ALLOCATE IN FILE'S MAP
	TRZ F,R.OMD+R.OMF+R.OMT	;INITIALIZE ALLOCATOR FLAGS

PPBF4:	MOVEM A,OBLK		;STORE FOR OUTPUTTER
	MOVEM B,OMACP		;AND SAVE POINTER TO BYTE
	PUSHJ P,CLRWBF		;CLEAR THE WRITE BUFFER
	MOVEI T,177		;NUMBER OF PDP10 WORDS IN BUFFER
	MOVEM T,OHED+2		;STORE FOR SOSLE
	MOVEI T,WBUF-1		;PLACE WHERE WORDS GO
	MOVEM T,OHED+1
PPBF1:	SOS OHED+2		;USE A COUNT
	AOS T,OHED+1		;COUNT WORD POSITION
	MOVEM W,0(T)		;STORE WORD IN WBUF
	JRST CPOPJ1		;OK RETURN.

PPBF2:	MOVE A,OBLK		;WHERE WAS LAST OUTPUT
	SKIPA B,OMACP		;AND ITS POINTER
PPBFN:	TRO F,R.OMF		;MARK SKIPPING A BLK
PPBFN1:	TRNN F,R.OMD		;WHICH WAY SCANNING BYTES?
	JRST PPBF2A		;FORWARD
	JRST PPBF6A		;BACKWARD
PPBFL1:	ILDB T,B		;GET A MASTER DIRECTORY BIT
	JUMPE T,PPBF4A		;JUMP IF FREE
PPBF2A:	CAIGE A,1076		;LOOKED AT ALL LEGAL BLKS?
	AOJA A,PPBFL1		;NO. LOOK ON
	JRST PPBFRV		;YES. REVERSE THE SCAN

PPBF4A:	HRRZ T,OBLK		;GET PREVIOUS WRITTEN BLK
	SUB T,A			;DISTANCE
	MOVMS T
	TRZE F,R.OMT		;AT THE TURNAROUND?
	JRST PPBF4C		;YES. FORGET THE SPACING THIS TIME
	CAIGE T,5		;SPACE FIVE APART
	JRST PPBFN		;TOO CLOSE TOGETHER
PPBF4C:	MOVEI T,1		;OK. ALLOCATE IT
	DPB T,B			;IN MASTER BYTE TABLE
	MOVE T1,B		;AND IN ITS OWN BYTE TABLE
	ADDI T1,FBMBUF-ODIREC
	ADD T1,FBMX
	DPB T,T1
	HRRM A,WBUF+177		;LINK TO NEXT BLK
	SKIPN OBVFLG		;NEED TO OBVERSE COMP THIS BLK?
	JRST PPBF4B		;NO.
	MOVE T,[XWD WBUF,TBUF]	;YES. COPY IT
	BLT T,TBUF+177
	PUSHJ P,OBVCOM
	MOVE T,[XWD TBUF,WBUF]
	BLT T,WBUF+177
PPBF4B:	SETZM OBVFLG
	CAMG A,OBLK
	SETOM OBVFLG		;GOING BACKWARDS NEXT BLK.
	PUSHJ P,PPBBLK		;FINALLY OUTPUT THE OLD BLK
	JRST PPBF4		;NOW CLEAR AND PUT W IN

PPBFL2:	ADD B,[XWD 010000,0]
	HLRZ T,B
	CAIN T,440100
	SUB B,[XWD 440000,1]
	LDB T,B			;GET BYTE FROM ODIREC
	JUMPE T,PPBF4A		;JUMP IF FREE
PPBF6A:	CAILE A,0		;TO FRONT OF TAPE?
	SOJA A,PPBFL2		;NO. LOOK ONWARD
PPBFRV:	TRZN F,R.OMF		;TAPE ENTIRELY FULL?
	JRST ERR20		;YES. LOSE
	TRC F,R.OMD		;CHANGE DIRECTION
	TRO F,R.OMT		;SUPPRESS SPACING FACTOR ON TURNAROUND
	JRST PPBFN1		;AND LOOK ONWARD
PPAVEN:				;USE SAME TAG FOR BOTH
PPBVEN:	SKIPLE OHED+2		;ANY SPACE IN BLK?
	JRST PPBV1		;YES
	SKIPL OBLK		;NO. STARTED OUTPUT FILE YET?
	JRST PPBV2		;YES. GET ANOTHER BLK
	SETZM EVSLEN		;CLEAR THE LENGTH IN BLKS OF THIS FILE
	SETZM EVSLAS		;AND FIRST AND LAST BLKS, IN CASE NONE
	SETZM EVSFBN		; ..
	MOVEI A,1		;NO. START AT BLK 1
	PUSHJ P,PVFREQ		;IS BLK FREE?
	  JRST PPBV3		;YES.
	CAIGE A,1100		;NO. TO EOT?
	AOJA A,.-3		;NO, LOOK ON
	JRST ERR20		;YES. TAPE FULL.

PPBV3:	MOVEM A,EVSFBN		;STORE FIRST BLK NUMBER FOR DIRECTORY
	PUSHJ P,PVALOC		;ALLOCATE AND LEAVE TRACKS
	TRZ F,R.OMF+R.OMD+R.OMT	;INIT FLAGS FOR ALLOCATOR
	SETZM OBVFLG		; ..
PPBV4:	MOVEM A,OBLK		;STORE THIS BLK NUMBER AS OUTPUT BLK
	PUSHJ P,CLRWBF		;CLEAR THE WRITE BUFFER
	MOVEI T,1		;SET UP BYTE POINTER TO SECOND VEN WORD
	MOVEM T,OHED+1		; ..
	MOVEI T,776		;NUMBER OF BYTES WHICH BLK WILL HOLD
	MOVEM T,OHED+2		;AFTER USING UP LINK.
PPBV1:	SOS OHED+2		;COUNT USING A BYTE
	AOS T,OHED+1		;AND GET ITS INDEX
	IDIVI T,4		;CONVERT TO STORE IT
	DPB CH,PPAVT1(T1)	;STORE BYTE
	JRST CPOPJ1		;OK RETURN

PPAVT1:	POINT 8,WBUF(T),17
	POINT 8,WBUF(T),09
	POINT 8,WBUF(T),35
	POINT 8,WBUF(T),27

PVFREQ:	PUSH P,A		;SAVE BLOCK NUMBER
	IDIVI A,40		;BITS IN TWO VEN WORDS
	MOVEI T,1		;CONVERT TO BIT POSITION
	LSH T,0(B)		; ..
	TDNE T,[XWD 037777,600000]
	LSH T,2			;IN LEFT HALF
	MOVSS T			;BUT WORDS IN OTHER ORDER
	MOVE T1,A		;COPY FOR ALLOCATOR
	TDNE T,VBMAPO+2(T1)	;FREE?
APOPJ1:	AOS -1(P)		;NO. SKIP RETURN
APOPJ:	POP P,A
	POPJ P,0

PVALOC:	IORM T,VBMAPO+2(T1)	;ALLOCATE IN MASTER MAP
	IORM T,FBMBUF(T1)	;AND INDIVIDUAL MAP
	MOVEM A,EVSLAS		;LAST BLOCK (SO FAR)
	AOS EVSLEN		;COUNT ANOTHER IN LENGTH
	POPJ P,0		;RETURN
PPBV2:	MOVE A,OBLK
PPBVN:	TRO F,R.OMF
PPBVN1:	TRNN F,R.OMD
	JRST PPBV2A
	JRST PPBV6A

PPBVL1:	PUSHJ P,PVFREQ		;FREE?
	  JRST PPBV4A		;YES. SEE IF FAR ENOUGH AWAY
PPBV2A:	CAIGE A,1077		;EOT?
	AOJA A,PPBVL1		;NO
	JRST PPBVRV		;YES. REVERSE DIRECTION

PPBV4A:	HRRZ T,OBLK		;GET LAST WRITTEN BLK
	SUB T,A			;DISTANCE
	MOVMS T			;MAGNITUDE OF IT
	TRZE F,R.OMT		;TURN-AROUND IN PROCESS?
	JRST PPBV4D		;YES. IGNORE SPACING
	CAIGE T,4		;FAR ENOUGH?
	JRST PPBVN		;NO
PPBV4D:	PUSHJ P,PVFREQ		;YES. RECOMPUTE T AND T1
	  SKIPA
	JRST ERR38		;THIS CANT BE BUSY - IT WAS JUST FREE
	PUSHJ P,PVALOC		;ALLOCATE THE BLOCK
	HRLM A,WBUF+0		;PUT LINK IN DATA BLK
	CAML A,OBLK		;WILL NEXT BLK BE WRITTEN BACKWARDS?
	JRST PPBV4C		;NO
	MOVN T,A		;YES. NEGATE THE BLK NUMBER AS FLAG
	ANDI T,177777		;ONLY 16 BITS
	HRLM T,WBUF+0		;STORE NEGATIVE
PPBV4C:	SKIPN OBVFLG		;WRITING BACKWARDS IN THIS CURRENT BLK?
	JRST PPBV4B		;NO
	MOVE T,[XWD WBUF,TBUF]	;YES. MUST OBV COM CURRENT DATA
	BLT T,TBUF+177		;COPY FOR OBVCOM RTN
	PUSHJ P,OBCVEN
	MOVE T,[XWD TBUF,WBUF]
	BLT T,WBUF+177
PPBV4B:	SETZM OBVFLG		;NOW SET UP FLAG FOR NEXT TIME
	CAMG A,OBLK		;WHICH WAY?
	SETOM OBVFLG		;BACKWARDS
	PUSHJ P,PPBBLK		;WRITE THE DATA
	JRST PPBV4		;SET UP WBUF FOR NEXT BLK IF ANY

PPBVL2:	PUSHJ P,PVFREQ		;FREE?
	  JRST PPBV4A		;YES
PPBV6A:	CAILE A,1		;TO FRONT OF TAPE?
	SOJA A,PPBVL2		;NO
PPBVRV:	TRZN F,R.OMF		;REVERSE. PASS ANY FREE ONES?
	JRST ERR20		;NO. ITS FULL
	TRC F,R.OMD		;YES. CHANGE DIRECTION FLAG
	TRO F,R.OMT		;FLAG IN TURN-AROUND
	JRST PPBVN1		;ON TO NEXT BLK
;CLOSE ROUTINES

CLS:	MOVE T1,OTYPEX		;GET TYPE OF OUTPUT FILE
	PUSHJ P,@CLST(T1)	;DISPATCH
	SETOM OBLK		;CLEAR USE OF THIS POINTER
	POPJ P,0		;RETURN FROM PROCES

CLST:	CLSNDT			;NON DECTAPE
	CLSTEN			;TEN DECTAPE
	CLSSIX			;SIX DECTAPE
	CLSMAC			;MAC DECTAPE
	CLSFIF			;PDP15 DECTAPE
	CLSVEN			;PDP11 DECTAPE

CLSNDT:	CLOSE OUTF,0		;CLOSE THE FILE
	MOVE T,ODEV		;GET OUTPUT DEVICE NAME
	CALLI T,CI.DCH		;DEVICE BITS
	TLNN T,DVDSK		;DISK?
	JRST CLSN2		;NO. NO PROTECTION
	MOVE A,TOFILE		;GET FILE NAME
	SKIPN	B,FOEXT		;GET FORCED EXTENSION
	HLLZ B,TOEXT		;EXTENSION
	SKIPE C,OPRT		;PROTECTION
	JRST CLSN1		;SPECIFIED.
	TRNN	F,R.SYS		;NOT SPEC.--IS THIS SYS?
	JRST	CLSN2		;NO--USE SYSTEM DEFAULT
	MOVEI	C,SYSPRT	;SET-UP STANDARD SYS PROTECTION
	CAMN	B,[SIXBIT /SYS/]  ;IF EXT IS SYS
	MOVEI	C,SSSPRT	;  THEN USE SPECIAL PROTECTION
CLSN1:	LSH C,↑D27		;IN RIGHT FIELD
	MOVE D,OPPN		;PROJ PROG NUMBER
	RENAME OUTF,A		;PUT PROT ON
	PUSHJ P,ERR25		;CAN'T RENAME
	CLOSE OUTF,0		;CLOSE AGAIN
CLSN2:	STATZ OUTF,740000	;ERRORS?
	JRST ERR21		;YES
	POPJ P,0		;NO.

CLSMAC:	MOVEI A,100		;DIRECTORY BLOCK NUMBER
CLSS3:	MOVEM A,ODIBKN		;SAVE BLK NUMBER (MAC OR SIX)
	SKIPG OBLK		;IS THERE AN OUTPUT BLOCK?
	JRST CLSM1		;NO. JUST WRITE DIR
	PUSHJ P,PPBBLK		;WRITE THE CURRENT BUFFER
CLSM1:	MOVE A,ODIBKN		;GET BLK NUMBER FOR DIRECTORY
	MOVEM A,OBLK		;FOR WRITER
	MOVE T,[XWD ODIREC,WBUF]
	BLT T,WBUF+177		;COPY INTO WRITE BUFFER
	PUSHJ P,PPBBLK		;AND WRITE IT ON DSK OR TAPE
	POPJ P,0		;END OF CLOSE ROUTINE
;PDP-15 FORMAT CLOSE ROUTINE

CLSFIF:	HLLOS WBUF+177		;-1 LINK IS EOF
	SKIPGE OBLK		;ACTUALLY WRITTEN?
	JRST CLSF1		;NO. JUST DUMP DIRECTORY
	SKIPN OBVFLG		;GOING BACKWARDS?
	JRST CLSF2		;NO
	MOVE T,[XWD WBUF,TBUF]	;YES. MUST SHUFFLE BITS
	BLT T,TBUF+177		; MOVE OVER
	PUSHJ P,OBVCOM		;SHUFFLE
	MOVE T,[XWD TBUF,WBUF]
	BLT T,WBUF+177		;MOVE BACK
CLSF2:	PUSHJ P,PPBBLK		;OUTPUT THE BLOCK
CLSF1:	MOVE T,[XWD FBMBUF,WBUF]	;PUT BIT MAP IN WBUF
	BLT T,WBUF+177
	MOVE T,FBMBLK		;WHERE IT GOES ON TAPE
	MOVEM T,OBLK		;TO OUTPUTTER'S ARG
	PUSHJ P,PPBBLK		;WRITE IT
	MOVE T,[XWD ODIRECT,WBUF]	;AND THE DIRECTORY ITSELF
	BLT T,WBUF+177		; ..
	MOVEI T,100		;WHERE IT LIVES ON TAPE
	MOVEM T,OBLK
	PUSHJ P,PPBBLK		;WRITE IT
	POPJ P,0		;DONE WITH CLOSE

;PDP-11 CLOSE ROUTINE

CLSVEN:	HRRZS WBUF+0		;CLEAR LINK. NO MORE TO WRITE.
	SKIPGE OBLK		;WRITE ANY AT ALL?
	JRST CLSV1		;NO. JUST DUMP DIRECTORY AND STUFF
	SKIPN OBVFLG		;YES. WHICH WAY WE GOING?
	JRST CLSV2		;FORWARD
	MOVE T,[XWD WBUF,TBUF]	;BACKWARD. HAVE TO SWAP DATA AROUND
	BLT T,TBUF+177
	PUSHJ P,OBCVEN
	MOVE T,[XWD TBUF,WBUF]
	BLT T,WBUF+177
CLSV2:	PUSHJ P,PPBBLK		;WRITE OUT THE BLOCK
CLSV1:	MOVE T,[XWD VBMAPO,WBUF]	;WRITE THE MASTER BIT MAP BLK
	BLT T,WBUF+177		;COPY TO WRITE BUFFER
	MOVE T,PBMBKO		;GET BK NUMBER WHERE IT GOES
	MOVEM T,OBLK		;FOR WRITER
	PUSHJ P,PPBBLK		;WRITE IT
	MOVE T,FBMBLK		;NOW READ THE FILE'S MAP BLK
	MOVEM T,OBLK		;(WILL WRITE IT IN A MINUTE)
	PUSHJ P,ROUTBT		;READ IT SO CAN UPDATE ONE FILE'S ENTRY
	  JRST ERR40		;OOPS
	MOVEI T,TBUF		;COMPUTE WHERE THE BITS GO
	ADD T,FBMX
	HRLI T,FBMBUF		;BLT WORD
	MOVEI T1,21(T)		;END CONDITION
	BLT T,0(T1)		;MOVE THE BITS FOR THIS FILE
	MOVE T,[XWD TBUF,WBUF]
	BLT T,WBUF+177		;COPY OVER FOR WRITING
	PUSHJ P,PPBBLK		;WRITE IT OUT
	MOVE C,EVSPOS		;NOW GET THE POSITION FOR OUTPUT SLOT IN ODIRECT
	MOVE T,EVSN1		;NAME PART 1
	PUSHJ P,PTVODW		;PUT IT IN ODIREC
	ADDI C,1		;TO NEXT HALF NAME
	MOVE T,EVSN2		;GET NAME PART 2
	PUSHJ P,PTVODW		;PUT IT IN ODIREC
	ADDI C,1		;TO EXT
	MOVE T,EVSEXT		;GET THE EXT
	PUSHJ P,PTVODW		;PUT IT IN ODIREC
	ADDI C,1		;NOW THE DATE
	MOVE T,EVSDAT		;ALREADY IN VEN FORMAT
	PUSHJ P,PTVODW		;PUT IT IN ODIREC
	ADDI C,2		;FIRST BLK NUMBER
	MOVE T,EVSFBN		;GET IT
	PUSHJ P,PTVODW		;PUT IT IN ODIREC
	ADDI C,1		;LAST BLOCK NUMBER
	MOVE T,EVSLEN		;GET IT
	PUSHJ P,PTVODW		;PUT IT IN ODIREC
	ADDI C,1		;AND LENGTH
	MOVE T,EVSLAS		;GET IT
	PUSHJ P,PTVODW		;PUT IT IN ODIREC
	ADDI C,1		;AND FINALLY PROTECTION CODE
	MOVE T,EVSPRT		;GET IT
	PUSHJ P,PTVODW		;PUT IT IN ODIREC
	MOVE T,ODIBKN		;BLOCK NUMBER THIS GOES IN
	MOVEM T,OBLK		;FOR WRITE RTN
	MOVE T,[XWD ODIREC,WBUF]	;MOVE IT TO WRITE BUFFER
	BLT T,WBUF+177		; ..
	PUSHJ P,PPBBLK		;OUT IT GOES
	POPJ P,0		;END OF PDP-11 CLOSE ROUTINE
;PDP6 FORMAT CLOSE ROUTINE

CLSSIX:	TLNE F,L.6DO		;DUMP OUTPUT?
	JRST CLSS1		;YES.
	HRRZS WBUF		;NO. CLEAR LINK
	HRRZ A,OHED+2		;GET USED WORDS COUNT THIS BFR
	MOVNS A
	ADDI A,177
	HRRM A,WBUF		;PUT INTO LINK WORD
	JRST CLSS2		;GO WRITE THE BLOCK

CLSS1:	HRRZ A,OHED+2		;GET USED WORDS IN DUMP FILE
	MOVNS A
	ADDI A,200
	ADDB B,OFILEL		;INTO OUTPUT FILE LENGTH
	MOVNS A			;MAKE IOWD FOR WHOLE FILE
	HRLZS A
	HRRI A,JOBSV6		;FIRST ADR MINUS ONE
	MOVE C,OFILEX		;GET DIRECTORY INDEX
	MOVEM A,ODIREC+3(C)	;PUT IOWD IN DIRECTORY
CLSS2:	MOVEI A,1		;DIRECTORY BLOCK NUMBER
	JRST CLSS3		;WRITE IT OUT

;PDP10 CLOSE ROUTINE

CLSTEN:	TLNN F,L.SCRO		;SCRATCH OUTPUT FILE?
	JRST CLSNDT		;NO. USE SYSTEM CLOSE
	SKIPG OBLK		;YES. ANY DATA WRITTEN?
	JRST CLST1		;NO
	MOVE T,OFIRBK		;OUTPUT FIRST BLK
	LSH T,10		;TO LINK BYTE
	MOVN T1,OHED+2		;USED WORDS IN LAST BK
	ADDI T1,177		; ..
	IOR T,T1		;OR INTO LINK
	HRRZM T,WBUF		;TO LINK IN WBUF, NO NEXT BLK
	PUSHJ P,PPBBLK		;OUTPUT THE BLOCK
CLST1:	USETO SCOF,144+1	;TO DIR BLK
	OUTPUT SCOF,ODIIOW	;OUTPUT THE DIR
	STATZ SCOF,760000	;PROBLEMS?
	JRST ERR3		;YES.
	POPJ P,0		;NO. RETURN FROM CLS
;DUMB ROUTINE TO SELECT THE CURRENT FILE TYPE.
;ARGS - EXTENSION IN RH OF A, SWITCHES IN C. RETURNS TYPE IN T

FT.C==1		;COMPRESSED SAVE FILE
FT.E==2		;EXPANDED SAVE FILE
FT.D==3		;DUMP (SIX) FILE
FT.S==4		;SBLK (MAC) FILE
FT.B==5		;RANDOM BINARY

SELFTP:	MOVEI T,FT.B		;IN CASE NOTHING ELSE SHOWS UP
	CAIE A,(SIXBIT /SVE/)	;CHECK FOR TEN SAVE EXTENSIONS
	CAIN A,(SIXBIT /SAV/)	; ..
	MOVEI T,FT.C		;YES
	CAIN A,(SIXBIT /LOW/)	;ONE MORE
	MOVEI T,FT.C
	CAIN A,(SIXBIT /XPN/)	;EXPANDED SAVE FILE?
	MOVEI T,FT.E		;YES.
	CAIN A,(SIXBIT /DMP/)	;SIX DUMP FILE?
	MOVEI T,FT.D		;YES
	TRNE C,SW.S		;SWITCHES OVERRIDING ABOVE?
	MOVEI T,FT.S		; S SWITCH
	TRNE C,SW.C		; ...
	MOVEI T,FT.C
	TRNE C,SW.D
	MOVEI T,FT.D
	TRNE C,SW.E
	MOVEI T,FT.E
	TRNE C,SW.B
	MOVEI T,FT.B
	POPJ P,0		;RETURN FILE TYPE
;SWITCH TABLE - INDEX BY LETTER FROM A
;CONTAINS XWD SET BIT(S), CLR BIT(S)

SWTAB:	XWD SW.A,SW.I				;A
	XWD SW.B,SW.C!SW.D!SW.E!SW.S!SW.A!SW.I	;B
	XWD SW.C,SW.B!SW.D!SW.E!SW.S!SW.A!SW.I	;C
	XWD SW.D,SW.B!SW.C!SW.E!SW.S!SW.A!SW.I	;D
	XWD SW.E,SW.B!SW.C!SW.D!SW.S!SW.A!SW.I	;E
	XWD SW.F,SW.M!SW.V!SW.O			;F
	XWD SW.G,0				;G
	XWD SW.H,0				;H
	XWD SW.I,SW.A				;I
	0					;J
	0					;K
	XWD SW.L,0				;L
	XWD SW.M,SW.F!SW.V!SW.O			;M
	0					;N
	XWD SW.O,SW.F!SW.M!SW.V			;O
	XWD SW.P,SW.Q!SW.R			;P
	XWD SW.Q,SW.P!SW.R			;Q
	XWD SW.R,SW.P!SW.Q			;R
	XWD SW.S,SW.B!SW.C!SW.D!SW.E!SW.A!SW.I	;S
	XWD 0,SW.M!SW.V!SW.O!SW.F		;T
	0					;U
	XWD SW.V,SW.F!SW.M!SW.O			;V
	0					;W
	0					;X
	0					;Y
	XWD SW.Z,0				;Z

.ZZ==1			;BITS
DEFINE M.SW(A)<
IRP<A>,<SW.'A==.ZZ
.ZZ==.ZZ+.ZZ>>

;NOTE THAT ALL 18 BITS ARE IN USE....
M.SW(<A,B,C,D,E,F,G,H,I,L,M,O,P,Q,R,S,V,Z>)

;THE FOLLOWING SWITCHES ARE MEANINGFUL ONLY ON THE SIDE OF LEFTARROW
; WHICH HAS A DECTAPE AS THE DEVICE

SW.TAP==SW.F!SW.L!SW.M!SW.O!SW.P!SW.Q!SW.R!SW.V!SW.Z
;DISPATCH TABLE FOR TYPE OF TRANSFER OPERATION

XARRAY:	XFRBB	;C TO C
	XFRCE	;C TO E
	XFRCD	;C TO D
	XFRCS	;C TO S
	XFRBB	;C TO B
	XFREC	;E TO C
	XFRBB	;E TO E
	XFRED	;E TO D
	XFRES	;E TO S
	XFRBB	;E TO B
	XFRDC	;D TO C
	XFRDE	;D TO E
	XFRBB	;D TO D
	XFRDS	;D TO S
	XFRBB	;D TO B
	XFRSC	;S TO C
	XFRSE	;S TO E
	XFRSD	;S TO D
	XFRBB	;S TO S
	XFRBB	;S TO B
	XFRBB	;B TO C
	XFRBB	;B TO E
	XFRBB	;B TO D
	XFRBB	;B TO S
	XFRBB	;B TO B
;TRANSFER ROUTINES

XFRBB:
XFRBBL:	PUSHJ P,RPB		;SIMPLE BINARY TRANSFER
	  JRST CLS		;END OF FILE
	PUSHJ P,PPB		;WRITE
	  JRST CLS
	JRST XFRBBL

XFRCE:	SETZM OCA		;CLEAR OUTPUT CORE ADDRESS
XCEL1:	PUSHJ P,RPB		;READ A POINTER OR JRST
	  JRST XCEX		;EOF
	JUMPGE W,XCEX		;JRST WORD
	MOVE CA,W		;GET THE BLKI POINTER
	HRRI CA,1(CA)		;MAKE AN AOBJN POINTER
XCEL2:	MOVEI T,0(CA)		;COMPARE WITH CURRENT OUTPUT ADDR
	CAMG T,OCA
	JRST XCE1		;OK. OUTPUT HERE
	MOVEI W,0		;NEED SOME ZEROES
	PUSHJ P,PPB		;..
	  JRST XCEX		;TROUBLE
	AOS OCA			;NEXT OUTPUT ADDRESS
	JRST XCEL2		;LOOP TO ADDR OF POINTER

XCE1:	CAME T,OCA		;MONOTONIC?
	PUSHJ P,ERR24		;NO. LOSES.
XCEL3:	PUSHJ P,RPB		;READ A WORD FROM BLK
	  JRST XCEX		;EOF OR ERR
	PUSHJ P,PPB
	  JRST XCEX
	AOS OCA			;COUNT OUTPUT ADDR
	AOBJN CA,XCEL3		;FINISH BLOCK
	JRST XCEL1		;GET ANOTHER BLOCK OR JRST

XCEX:	JRST CLS		;END OF FILE
;HERE WHEN I/O IS FROM PDP15 TAPE TO 36BIT OUTPUT

PRIFIF:	PUSH P,[EPROCS]
	HLRZ T,TIEXT		;INPUT EXTENSION OF 15 FILE
	CAIN T,(SIXBIT /ABS/)	;DUMP OF CORE?
	JRST XFRFAB		;YES.
	PUSHJ P,RPB		;NO. ASSUME IOPS FORMAT
	 JRST CLS		;EOF?
	LDB T,[POINT 4,W,17]	;IOPS MODE BYTE
	CAIN T,2		;IOPS ASCII?
	JRST XFRFTB		;YES. TEXT HANDLING
	JUMPE T,XFRFB		;MODE 0 IS IOPS BIN
XFRFBL:	PUSH P,W		;SAVE 36 BIT WORD
	HLRZS W			;GET 18 BIT WORD
	PUSHJ P,PPB		;OUTPUT IT
	 JRST CLS
	POP P,W			;GET BACK INPUT WORDS
	HRRZS W			;SECOND WORD (18 BITS)
	PUSHJ P,PPB		;SEND IT TOO
	 JRST CLS
	PUSHJ P,RPB		;GET SOME MORE
	 JRST CLS		;EOF
	JRST XFRFBL		;LOOP

XFRFAB:	PUSHJ P,RPB		;FOR CORE DUMP, TRANSFER WHOLE THING.
	 JRST CLS		;END OF FILE
	JRST XFRFBL		;LOOP

XFRFTB:	SETZM FITXW1		;FIFTEEN INPUT TEXT WORD
	MOVE T,[XWD 440700,FITXW1]
	MOVEM T,FITXP1
XFRFTC:	MOVEM W,FTEMP		;SAVE INPUT DATA FOR CKSM
	LDB T,[POINT 8,FTEMP,8]	;GET WORD-PAIR COUNT
	MOVEM T,FCOUNT		;SAVE IT FOR LOOP CONTROL
	JRST XFTB1		;COUNT DOWN THIS HEADER PAIR
XFTBL:	PUSHJ P,RPB		;READ A PAIR
	 JRST XFICLS		;END OF FILE
	MOVEM W,FITXW2
	MOVE T,[XWD 440700,FITXW2]
	MOVEM T,FITXP2
	ILDB CH,FITXP2
	PUSH P,CH
	CAIN CH,12
	SETZM XFILFQ
	MOVEI CH,12
	AOSN XFILFQ
	PUSHJ P,FIPPA
	POP P,CH
	PUSHJ P,FIPPA
REPEAT 4,<
		ILDB CH,FITXP2
		PUSHJ P,FIPPA
>
XFTB1:	SOSLE FCOUNT		;DONE?
	JRST XFTBL		;NO
	SETOM XFILFQ		;FLAG PROB WANT LINEFEED NEXT
	PUSHJ P,RPB		;INPUT PLEASE
	 JRST XFICLS		;EOF
	TLNN W,-1		;NON-BLANK?
	JRST .-3		;BLANK
	JRST XFRFTC		;NON-BLANK HEADER. PROCESS IT

FIPPA:	MOVE T,FITXP1
	TLNN T,760000
	PUSHJ P,FIPPA1
	IDPB CH,FITXP1
	POPJ P,0

FIPPA1:	MOVE W,FITXW1
	PUSHJ P,PPB
	 JRST CLS
	MOVE T,[XWD 440700,FITXW1]
	MOVEM T,FITXP1
	SETZM FITXW1
	POPJ P,0

XFICLS:	MOVEI CH,12
	SKIPGE XFILFQ
	PUSHJ P,FIPPA
	PUSHJ P,FIPPA1
	JRST CLS
XFRFB:	MOVEM W,FTEMP
	LDB T,[POINT 8,FTEMP,8]
	MOVEM T,FCOUNT
	JRST XFIBN

XFIBL:	PUSHJ P,RPB
	 JRST CLS
	PUSH P,W
	HLRZS W
	PUSHJ P,PPB
	 JRST CLS
	POP P,W
	ANDI W,-1
	PUSHJ P,PPB
	 JRST CLS
XFIBN:	SOSLE FCOUNT
	JRST XFIBL
	PUSHJ P,RPB
	 JRST CLS
	TLNN W,-1
	JRST .-3
	JRST XFRFB

;HERE ON 36 BIT OUTPUT, PDP11 INPUT

PRIVEN:	PUSH P,[EPROCS]		;FAKE CALL FROM DISPATCH BY PUSHJ
	MOVE T,OSW
	IOR T,ISW		;SEE IF ANY SWITCHES OF INTEREST
	TRNE T,SW.I
	JRST PIVIMG		;TRANSFER 8 BITS PER 36 BIT WORD
	TRNE T,SW.A		;ASCII?
	JRST PIVASC		;YES. CONVERT TO PDP10 PACKING ASCII
	TRNE T,SW.B		;BINARY?
	JRST PIVBIN		;YES. 32 BITS IN 36 BIT WD
	HLLZ T,TOEXT		;NO. SEE IF EXT DECLARES BINARY.
	MOVSI T1,-VBINXL
	CAMN T,VBINXT(T1)	;CHECK AN EXT
	JRST PIVBIN		;MATCHES. PROCESS BINARY
	AOBJN T1,.-2		;LOOP THRU ALL LISTED EXTS
	JRST PIVASC		;NO. ASSUME IT IS ASCII

VBINXT:	SIXBIT /BIN/
	SIXBIT /OBJ/
	SIXBIT /SYS/
	SIXBIT /LDA/
	SIXBIT /LDR/
	SIXBIT /LOD/
	SIXBIT /LBO/
	SIXBIT /MFD/
	SIXBIT /UFD/
	SIXBIT /SYM/
VBINXL==.-VBINXT
PIVASC:	SETZM FITXW1		;ASCII. BORROW PDP FIFTEEN ROUTINE
	MOVE T,[XWD 440700,FITXW1]
	MOVEM T,FITXP1
PIVASL:	PUSHJ P,RPAVEN		;GET AN EIGHT BIT BYTE
	 JRST PIVAS1		;EOF
	JUMPE CH,PIVASL		;SKIP NULLS
	PUSHJ P,FIPPA		;STASH SEVEN OF THEM
	JRST PIVASL

PIVAS1:	PUSHJ P,FIPPA1		;OUTPUT PARTIAL WD
	JRST CLS

PIVIMG:	PUSHJ P,RPAVEN		;GET 8 BITS
	 JRST CLS
	MOVE W,CH
	PUSHJ P,PPB		;WRITE IN 36 BIT WD
	  JRST CLS
	JRST PIVIMG

PIVBIN:	PUSHJ P,RPBVEN
	 JRST CLS
	MOVEM W,FITXW1		;SAVE FIRST 16 BITS
	PUSHJ P,RPBVEN		;GET SECOND
	  JRST PIVBIX		;NO SECOND. FILL WITH 0
	HRL W,FITXW1		;MAKE 32 BIT WORD
	PUSHJ P,PPB		;COPY 32 OF 36 BITS STRAIGHT FROM TAPE
	  JRST CLS
	JRST PIVBIN		;LOOP

PIVBIX:	HRLZ W,FITXW1		;GET FIRST 16 BITS IN LH
	PUSHJ P,PPB
	  JRST CLS
	JRST CLS		;END OF FILE
;HERE WHEN OUTPUT TAPE IS PDP FIFTEEN STYLE. INPUT MAY BE TOO?

PROFIF:	PUSH P,[EPROCS]
	MOVE T,ITYPEX		;SEE IF INPUT IS A FIFTEEN ALSO
	CAIN T,TYPFIF
	JRST XFRBB		;YES. DO BINARY XFR
	CAIN T,TYPVEN		;IS INPUT AN ELEVEN?
	JRST ERR36		;YES. CANT DO THAT (YET?)
	HLRZ T,TOEXT		;NO. WHAT KIND OF FILE?
	MOVE T1,ISW
	IOR T1,OSW		;GET SWITCHES
	TRNE T1,SW.A		;A SWITCH OVERRIDES EXT DEFAULT
	JRST PROFIA		;YES.
	TRNN T1,SW.I		;I SWITCH FORCES BINARY TRANSFER
	CAIN T,(SIXBIT /ABS/)
	JRST PROFAB
	CAIN T,(SIXBIT /BIN/)
	JRST POFBIN
PROFIA:	SETZM FOTXP1		;ASSUME TEXT. CLEAR FOR RPA

POFTL1:	MOVEI T,<5*176>		;SET MAX NUMBER CHARACTERS
	MOVEM T,IOPSOC
	MOVE T,[POINT 7,IOPSOB+1]
	MOVEM T,IOPSOP
	SETZM IOPSOB
	MOVE T,[XWD IOPSOB,IOPSOB+1]
	BLT T,IOPSOB+177
POFTL2:	PUSHJ P,FORPA
	  JRST POFTCL
	SOSL IOPSOC
	IDPB CH,IOPSOP
	CAIN CH,15
	JRST POFTEL		;TEXT END OF LINE
	JRST POFTL2

POFTEL:	HRRZ T,IOPSOP
	SUBI T,IOPSOB-1		;WORDS ACTUALL WRITTEN PLUS HDR
	ANDI T,377
	LSH T,11
	MOVEI T1,2(T)
	HRLZM T1,IOPSOB
POFTE2:	LDB T,[POINT 8,IOPSOB,8]
	MOVEM T,IOPSOC
	SKIPE OHED+2		;NEW BLK BEING STARTED?
	CAMG T,OHED+2		;WILL IT FIT IN CURRENT OUTPUT BLK?
	JRST POFTE1		;YES.
	MOVEI W,0
	PUSHJ P,PPB
	 JRST CLS
	JRST POFTE2
POFTE1:	MOVEI CKS,0
	HLRZ T1,IOPSOB-1(T)
	HRRZ T2,IOPSOB-1(T)
	ADD CKS,T1
	ADD CKS,T2
	SOJG T,.-4
	MOVNS CKS
	HRRM CKS,IOPSOB
	MOVEI CKS,0
POFTLL:	MOVE W,IOPSOB(CKS)
	PUSHJ P,PPB
	 JRST CLS
	ADDI CKS,1
	CAMGE CKS,IOPSOC
	JRST POFTLL
	JRST POFTL1

FORPA:	MOVE T,FOTXP1
	TLNN T,760000
	JRST FORPA1
	ILDB CH,FOTXP1
	JUMPE CH,FORPA
	JRST CPOPJ1

FORPA1:	MOVE T,[XWD 440700,FOTXW1]
	MOVEM T,FOTXP1
	PUSHJ P,RPB
	  POPJ P,0
	MOVEM W,FOTXW1
	JRST FORPA

POFTCL:	MOVE W,[XWD 001005,776773]
	PUSHJ P,PPB
	 JRST CLS
	JRST CLS
PROFAB:	TLZ F,L.6DO
POFAL1:	PUSHJ P,RPB
	 JRST CLS
	TLCE F,L.6DO
	JRST POFAB1
	HRLZM W,FOTXW1
	MOVE T,OHED+2
	CAILE T,1
	JRST POFAL1
	TLZ F,L.6DO
POFAB2:	PUSHJ P,PPB
	 JRST CLS
	JRST POFAL1

POFAB1:	HLL W,FOTXW1
	JRST POFAB2

POFBIN:
POFBL1:	MOVEI T,30
	MOVEM T,IOPSOC
	MOVE T,[POINT 18,IOPSOB+1]
	MOVEM T,IOPSOP
	SETZM IOPSOB
	MOVE T,[XWD IOPSOB,IOPSOB+1]
	BLT T,IOPSOB+177
POFBL2:	PUSHJ P,RPB
	 JRST POFBCL
	IDPB W,IOPSOP
	SOSLE IOPSOC
	JRST POFBL2

	PUSHJ P,POFEBB
	JRST POFBL1

POFBCL:	PUSHJ P,POFEBB
	MOVE W,[XWD 001005,776773]
	PUSHJ P,PPB
	 JRST CLS
	JRST CLS
POFEBB:	HRRZ T,IOPSOP
	SUBI T,IOPSOB-1
	ANDI T,377
	LSH T,11
	HRLZM T,IOPSOB
	MOVEI CKS,0
POFEB2:	LDB T,[POINT 8,IOPSOB,8]
	MOVEM T,IOPSOC
	SKIPE OHED+2
	CAMG T,OHED+2
	JRST POFEB1
	MOVEI W,0
	PUSHJ P,PPB
	 JRST CLS
	JRST POFEB2

POFEB1:	MOVEI CKS,0
	HLRZ T1,IOPSOB-1(T)
	HRRZ T2,IOPSOB-1(T)
	ADD CKS,T1
	ADD CKS,T2
	SOJG T,.-4
	MOVNS CKS
	HRRM CKS,IOPSOB
	MOVEI CKS,0
POFEBL:	MOVE W,IOPSOB(CKS)
	PUSHJ P,PPB
	 JRST CLS
	ADDI CKS,1
	CAMGE CKS,IOPSOC
	JRST POFEBL
	POPJ P,0
;HERE WHEN OUTPUT TAPE IS PDP ELEVEN STYLE. INPUT MAY BE TOO?

PROVEN:	PUSH P,[EPROCS]		;FAKE CALL FROM PROCES DISPATCH
	MOVE T,ITYPEX		;SEE WHAT THE INPUT TAPE IS
	CAIN T,TYPVEN		;ELEVEN ALSO?
	JRST PRVV		;YES. PROCESS ELEVEN TO ELEVEN.
	CAIN T,TYPFIF		;FIFTEEN?
	JRST ERR36		;YES. NOT IMPLEMENTED.
	HLLZ T,TOEXT		;NO. INPUT IS 36 BIT. WHAT KIND OF FILE?
	MOVE T1,ISW		;GET SWITCHES FOR INPUT
	IOR T1,OSW		;AND OUTPUT
	TRNE T1,SW.A		;ASCII SPECIFIED?
	JRST PROVA		;YES.
	TRNE T1,SW.I		;IMAGE (8 BIT) SPECIFIED?
	JRST PROVI		;YES.
	TRNE T,SW.B		;BINARY?
	JRST PROVB		;YES.
	MOVSI T1,-VBINXL	;SEE IF EXT FORCES BINARY TRANSFER
	CAMN T,VBINXT(T1)
	JRST PROVB		;YES
	AOBJN T1,.-2		;LOOP
				;NO. ASSUME ASCII IF NO SWITCH OR SPECIAL EXT
PROVA:	SETZM FOTXP1		;CLEAR POINTER FOR FIRST BYTE
PROVAL:	PUSHJ P,FORPA		;READ FROM 36 BIT WORD INTO CH
	  JRST CLS		;END OF FILE
	PUSHJ P,PPAVEN		;OUTPUT TO ELEVEN, FROM CH
	  JRST CLS		;ERROR ON OUTPUT. CLOSE FILE.
	JRST PROVAL		;LOOP TILL EOF

PRVV:	PUSHJ P,RPBVEN		;GET 16 BITS
	  JRST CLS		;EOF
	MOVEM W,FITXW1		;SAVE IT
	PUSHJ P,RPBVEN		;GET 16 MORE BITS
	  JRST PRVV1		;END OF FILE
	HRL W,FITXW1		;MAKE 32 BITS
	PUSHJ P,PROVB1		;OUTPUT 32 BITS
	JRST PRVV		;LOOP

PRVV1:	HRLZ W,FITXW1		;GET THE 16 BITS
	PUSHJ P,PROVB1		;OUTPUT WITH 16 ZEROES AFTER THEM
	JRST CLS		;AND CLOSE THE FILE
PROVI:	PUSHJ P,RPB		;GET 36 BITS
	  JRST CLS		;END OF FILE
	MOVE CH,W		;OUTPUT THEM
	ANDI CH,377		;JUST EIGHT BITS OF THE WORD
	PUSHJ P,PPAVEN		;OUTPUT THEM
	  JRST CLS		;ERROR
	JRST PROVI		;LOOP UNTIL EOF

PROVB:	PUSHJ P,RPB		;READ 36 BITS
	  JRST CLS		;END OF FILE
	PUSHJ P,PROVB1		;OUTPUT 32 BITS
	JRST PROVB		;LOOP

PROVB1:	MOVEM W,FOTXW1		;STORE 32 BITS
	LDB CH,[POINT 8,FOTXW1,17]
	PUSHJ P,PPAVEN		;OUTPUT FIRST 8
	  JRST CLS		;ERROR ON OUTPUT. CLOSE FILE.
	LDB CH,[POINT 8,FOTXW1,9]
	PUSHJ P,PPAVEN		;OUTPUT SECOND 8
	  JRST CLS		;ERROR ON OUTPUT. CLOSE FILE.
	LDB CH,[POINT 8,FOTXW1,35]
	PUSHJ P,PPAVEN		;THIRD EIGHT
	  JRST CLS		;ERROR ON OUTPUT. CLOSE FILE.
	LDB CH,[POINT 8,FOTXW1,27]
	PUSHJ P,PPAVEN		;FOURTH EIGHT
	  JRST CLS		;ERROR ON OUTPUT. CLOSE FILE.
	POPJ P,0		;RETURN FROM 32 BIT HANDLING SUBR
XFRCD:	MOVEI CA,JOBSV6+1		;OUTPUT ADDRESS AT START
	MOVEM CA,OCA
XCDL1:	PUSHJ P,RPB		;READ A POINTER WORD
	  JRST XCDX		;EOF
	JUMPGE W,XCDX		;JRST WORD.
	MOVE CA,W		;POINTER. GET ADDRESS
	HRRI CA,1(CA)		;AOBJN, NOT BLKI
XCDL2:	MOVEI T,0(CA)		;CURRENT ADDRESS IN AOBJN BLOCK
	CAMG T,OCA		;NEED TO FILL WITH ZEROES?
	JRST XCD1		;NO
	MOVEI W,0		;YES.
	PUSHJ P,PPB		;OUTPUT A ZERO
	  JRST XCDX		;ERROR
	AOS OCA			;COUNT THE OUTPUT ADDRESS
	JRST XCDL2		;SEE IF ENOUGH

XCD1:
XCDL3:	MOVEI T,0(CA)		;WHERE IN BLOCK?
	CAIG T,JOBSV6		;BELOW LOWEST LEGAL ADDR?
	JRST XCDN3		;YES. DISCARD WORD.
	CAME T,OCA		;AT CURRENT OUTPUT?
	JRST ERR24		;NO. NON-MONOTONIC
	PUSHJ P,RPB		;READ A WORD
	  JRST XCDX		;EOF
	PUSHJ P,PPB		;WRITE THE WORD
	  JRST XCDX		;ERROR
	AOS OCA			;OUTPUT ADDRESS UP ONE
XCDN3:	AOBJN CA,XCDL3		;LOOP FOR WHOLE AOBJN BLOCK
	JRST XCDL1		;NEXT BLK OR JRST

XCDX:	JRST CLS		;END OF FILE
XFRCS:	PUSHJ P,OUTMRL		;OUTPUT MAC RIM LOADER
	  JRST XCSX		;ERROR
XCSL1:	PUSHJ P,RPB		;GET A POINTER OR JRST WORD
	  JRST XCSX		;EOF
	JUMPGE W,XCSA		;JRST WORD
	MOVE CA,W		;POINTER
	ADDI W,1		;MAKE AOBJN NOT BLKI
	MOVE CKS,W		;START CHECKSUM OF THIS BLOCK
	PUSHJ P,PPB		;OUTPUT POINTER
	  JRST XCSX		;ERROR

XCSL2:	ROT CKS,1		;CHECKSUM
	PUSHJ P,RPB		;READ A DATUM FROM TEN FILE
	  JRST XCSX		;BAD END
	ADD CKS,W		;CHECKSUM
	PUSHJ P,PPB		;OUTPUT THE WORD TO MAC FILE
	  JRST XCSX		;ERROR
	AOBJN CA,XCSL2		;LOOP THROUGH AOBJN BLOCK
	MOVE W,CKS		;END OF BLOCK. OUTPUT CKSUM
	PUSHJ P,PPB		; ..
	  JRST XCSX
	JRST XCSL1		;READ NEXT POINTER OR JRST

XCSA:	PUSHJ P,PPB		;OUTPUT THE FINAL JRST WORD
	  JRST XCSX
	PUSHJ P,PPB		;TWICE (NO SYMS)
	  JRST XCSX
XCSX:	JRST CLS		;END OF FILE
XFRDC:	MOVEI T,JOBSV6+1	;6 TO TEN DMP TO SAV
	JRST XDC1		;JUMP INTO ROUTINE BELOW

XFREC:	MOVEI CA,17		;EXPANDED TO COMPRESSED
XECL0:	PUSHJ P,RPB		;READ EXPANDED FILE
	  JRST XECX		;ERROR
	SOJGE CA,XECL0		;DISCARD FIRST 20 LOCS OF EXP FILE
	MOVEI T,20		;LOWEST ADDRESS WANTED
XDC1:	MOVEM T,ICA		;ADDRESS ABOUT TO GET FROM INPUT FILE
	SETZB CA,OCA		;CLEAR OUTPUT POINTERS
	SETZM SAVSTA		;NO STARTING ADDRESS KNOWN YET
XECL1:	PUSHJ P,RPB		;READ INPUT WORD
	  JRST XECE		;END OF FILE
	JUMPE W,XEC1		;XERO WORD FROM INPUT?
	MOVEM W,XBUF(CA)	;PUT INTO TRANSFER BUFFER
	ADDI CA,1		;COUNT SIZE OF XFR BUF
	CAIGE CA,200		;FULL?
	JRST XECL1		;NO.
	PUSHJ P,XECOBK		;YES. OUTPUT THIS BLOCK AS ONE AOBJN WD
	  JRST XECX		;ERROR
	JRST XECL1		;READ SOME MORE.

XEC1:	JUMPE CA,XEC2		;ZERO IN. NEED TO WRITE BLK?
	PUSHJ P,XECOBK		;YES. DO SO.
	  JRST XECX		;ERROR
XEC2:	AOS ICA			;COUNT INPUT ADDRESS
	JRST XECL1		;AND GO ON.

XECE:	JUMPE CA,XECE2		;NEED TO OUTPUT A BLOCK?
	PUSHJ P,XECOBK		;YES. DO.
	  JRST XECX		;ERROR
XECE2:	SKIPE W,SAVSTA		;HAS A NON-ZERO START ADR BEEN SEEN?
	TLOA W,(JRST)		;YES. MAKE A JRST TO IT.
	MOVSI W,(HALT)		;OUTPUT JRST WORD (NO SA KNOWN)
	PUSHJ P,PPB		; ..
	  JRST XECX		;ERROR
XECX:	JRST CLS		;END OF FILE
XECOBK:	MOVN W,CA		;OUTPUT XBUF BLOCK
	HRLZS W			;MAKE COUNT OF BUFFER
	HRR W,ICA		;ADDRESS OF BUFFER STARTING IN CORE
	HRRI W,-1(W)		;MINUS ONE FOR BLKI PTR
	PUSHJ P,PPB		;OUTPUT THE POINTER
	  POPJ P,0		;ERROR
	SETZB T,OCA		;CLEAR COUNT
XECL2:	MOVE W,XBUF(T)		;GET A WORD FROM XBUF
	PUSHJ P,PPB		;OUTPUT IT
	  POPJ P,0		;ERROR
	AOS T,ICA		;COUNT INPUT ADDRESS
	CAIN T,.JOBSA+1		;IS IT WHERE START ADDR LIVES?
	HRRZM W,SAVSTA		;YES. SAVE IT.
	AOS T,OCA		;COUNT AMT OF XBUF WRITTEN
	CAIGE T,0(CA)		;ALL OF IT?
	JRST XECL2		;NO.
	MOVEI CA,0		;YES. CLEAR COUNTER, GO ON
	JRST CPOPJ1		;SUCCESSFUL RETURN

XFRED:	MOVEI CA,JOBSV6		;EXPANDED TO DUMP (SIX)
XEDL0:	PUSHJ P,RPB		;DISCARD WORDS UP TO SIX STARTER
	  JRST XEDX		;ERROR
	SOJGE CA,XEDL0		;COUNT DOWN JUNK
	JRST XFRBB		;FROM HERE ON, ITS A COPY.

XFRDE:	MOVEI CA,JOBSV6		;DUMP (SIX) TO EXPANDED
XDEL0:	MOVEI W,0		;WRITE OUT SOME LEADING ZEROES
	PUSHJ P,PPB		; ..
	  JRST XDEX		;ERROR
	SOJGE CA,XDEL0		;LOOP FOR ENOUGH ZEROES
	JRST XFRBB		;AND TRANSFER REST AS BINARY

XEDX:
XDEX:	JRST CLS		;ERROR EOF
XFRDS:	MOVEI T,JOBSV6+1	;DUMP TO SBLK
	JRST XDS1		;INTO ROUTINE BELOW

XFRES:	MOVEI CA,17		;EXPANDED TO SBLK
XESL0:	PUSHJ P,RPB		;READ AN AC FROM EXP FILE
	  JRST XESX		;ERROR
	SOJGE CA,XESL0		;DISCARD THE AC'S FROM EXP FILE
	MOVEI T,20		;NEXT ADDRESS TO COME IN
XDS1:	MOVEM T,ICA		;STORE NEXT INPUT ADDRESS
	PUSHJ P,OUTMRL		;OUTPUT MAC RIM LOADER
	  JRST XESX
	SETZB CA,OCA		;CLEAR OUTPUT COUNTERS
XESL1:	PUSHJ P,RPB		;READ A CORE WORD FROM EXP FILE
	  JRST XESX		;END OF FILE
	JUMPE W,XES1		;ZERO IN INPUT?
	MOVEM W,XBUF(CA)	;NO. STORE DATUM
	ADDI CA,1		;COUNT FILLING XFER BUFFER
	CAIGE CA,200		;FULL?
	JRST XESL1		;NO. READ ON
	PUSHJ P,XESOBK		;YES. OUTPUT BLOCK
	  JRST XESX		;ERROR
	JRST XESL1		;READ ON.

XES1:	JUMPE CA,XES2		;ANYTHING TO OUTPUT?
	PUSHJ P,XESOBK		;YES. DO SO
	  JRST XESX		;ERROR
XES2:	AOS ICA			;COUNT THIS ZERO
	JRST XESL1		;AND READ ON

XESX:	MOVSI W,(HALT)		;NO START ADDRESS KNOWN
	PUSHJ P,PPB		;OUTPUT JRST WORD
	  JFCL
	PUSHJ P,PPB		;TWICE
	  JFCL
	JRST CLS		;END OF FILE
XESOBK:	MOVN W,CA		;ROUTINE TO OUTPUT BLOCK OF SBLK
	HRLZS W			;MAKE IOWD
	HRR W,ICA		;GET ADDRESS FOR START OF BLOCK
	MOVE CKS,W		;INITIAL CHECKSUM
	PUSHJ P,PPB		;OUTPUT AOBJN PTR
	  POPJ P,0		;ERROR
	SETZB T,OCA		;CLEAR OUTPUT COUNTER
XESL2:	MOVE W,XBUF(T)		;GET OUTPUT DATUM
	ROT CKS,1		;PUT IT IN CKSUM
	ADD CKS,W		; ..
	PUSHJ P,PPB		;OUTPUT THE DATUM
	  POPJ P,0		;ERROR
	AOS ICA			;COUNT TRANSFERRED INPUT WORD
	AOS T,OCA		;HOW MUCH OF BLOCK XFRD
	CAIGE T,0(CA)		;ALL OF IT?
	JRST XESL2		;NOT YET
	MOVEI CA,0		;YES. CLEAR COUNT OF FILLED BFR
	MOVE W,CKS		;OUTPUT THE CHECKSUM
	PUSHJ P,PPB		; ..
	  POPJ P,0		;ERROR
	JRST CPOPJ1		;OK RETURN.
OUTMRL:	MOVE CA,[XWD -MRLL,MRL]	;POINTER TO LOADER
OUTMR1:	MOVE W,0(CA)		;GET A WORD OF IT
	PUSHJ P,PPB		;OUTPUT IT
	  POPJ P,0		;ERROR
	AOBJN CA,OUTMR1		;LOOP FOR ALL
	JRST CPOPJ1		;SUCCESS RETURN

MRL:	DATAI PTR,4
	JUMPGE 16,16
	DATAI PTR,5
	JSP 14,30
	DATAI PTR,6
	DATAI PTR,0(16)
	DATAI PTR,7
	ROT 15,1
	DATAI PTR,10
	ADD 15,0(16)
	DATAI PTR,11
	AOBJN 16,5
	DATAI PTR,12
	MOVEI 14,33
	DATAI PTR,13
	JRST 30
	DATAI PTR,30
	CONSO PTR,10
	DATAI PTR,31
	JRST 30
	DATAI PTR,32
	JRST 0(14)
	DATAI PTR,33
	DATAI PTR,16
	DATAI PTR,34
	CAMN 15,16
	DATAI PTR,35
	JUMPA 1
	DATAI PTR,36
	HALT
	JRST 1
MRLL==.-MRL
XFRSC:	SETOM OCA		;SBLK TO COMPRESSED
	PUSHJ P,RPB		;SKIP TO CUE WORD
	  JRST XSCX		;ERROR
	CAME W,[JRST 1]		;CUE?
	JRST XFRSC		;NOT YET.

XSCL1:	PUSHJ P,RPB		;GET POINTER OR JRST WORD
	  JRST XSCX		;EOF OR ERROR
	JUMPGE W,XSCA		;JRST WORD
	MOVE CKS,W		;AOBJN BLK. SET UP CKS
	HLL CA,W		;GET COUNT
	SKIPGE OCA		;OR IF DATA,
	MOVE CA,W		;GET COUNT AND ADDR
	SKIPL OCA		;SYMS OR DATA?
	HRRI W,0(CA)		;SYMS. PUT AFTER DATA.
	HRRI W,-1(W)		;MAKE BLKI PTR
	PUSHJ P,PPB		;OUTPUT POINTER
	  JRST XSCX		;ERROR
XSCL2:	PUSHJ P,RPB		;READ A DATUM
	  JRST XSCX		;ERROR
	ROT CKS,1		;CHECKSUM IT
	ADD CKS,W		; ..
	PUSHJ P,PPB		;OUTPUT IT
	  JRST XSCX		;ERROR
	AOBJN CA,XSCL2		;COUNT THRU BLK
	PUSHJ P,RPB		;READ CHECKSUM
	  JRST XSCX		;ERROR
	CAME W,CKS		;CHECK IT
	PUSHJ P,CKSERR		;NO GOOD
	JRST XSCL1		;READ ANOTHER BLK

XSCA:	AOSG OCA		;COUNT OUTPUT ADDRESS AS FLAG
	JRST XSCL1		;JUST FIRST ONE. GO ON
	PUSHJ P,PPB		;OUTPUT THE JRST WORD AT END
	  JRST XSCX		;ERROR
XSCX:	JRST CLS		;END OF FILE
XFRSD:	MOVEI CA,JOBSV6+1	;FIRST ADDRESS WANTED
	MOVEM CA,OCA		;SAVE IT
	MOVEM CA,ICA
	JRST XSDL0A		;INTO PROCESSING LOOP

XFRSE:	MOVEI CA,20		;SBLK TO EXPANDED
	MOVEM CA,OCA		;STORE COUNT
	MOVEM CA,ICA		;STORE INPUT ADDRESS
XSDL0:	MOVEI W,0		;OUTPUT A ZERO
	PUSHJ P,PPB		; ..
	JRST XSDX		;ERR
	SOJG CA,XSDL0		;LOOP
	MOVE CA,OCA		;GET OUTPUT CURRENT ADDRESS

XSDL0A:	PUSHJ P,RPB		;READ FOR MAC CUE
	  JRST XCDX		;ERR
	CAME W,[JRST 1]		;CUE?
	JRST XSDL0A		;NOT YET.
XSDL1:	PUSHJ P,RPB		;READ POINTER OR JRST
	  JRST XSDX		; ERR
	JUMPGE W,XSDX		;JRST WORD
	MOVE CA,W		;GET POINTER
	MOVE CKS,W		;START CHECK SUM
XSDL2:	MOVEI T,0(CA)		;CHECK CONTINUITY
	CAMG T,OCA		; ..
	JRST XSD1		;BREAK
	MOVEI W,0		;OUTPUT SOME ZEROS
	AOS OCA			;COUNT OUTPUT ADDRESS
	PUSHJ P,PPB		;AND OUTPUT THE ZERO
	  JRST XSDX		;ERR
	JRST XSDL2		;LOOP

XSD1:
XSDL3:	MOVEI T,0(CA)		;CHECK MONOTONICITY
	CAMG T,ICA		; ..
	JRST XSDN3		;BELOW STARTER
	CAME T,OCA		;AT OUTPUT?
	JRST ERR24		;NON-MONOTONIC
	PUSHJ P,RPB		;GOOD. GET DATUM
	  JRST XSDX		;ERR
	ROT CKS,1		;COMPUTE CHECK
	ADD CKS,W		; ..
	PUSHJ P,PPB		;OUTPUT DATUM
	  JRST XSDX		;ERR
	AOS OCA			;COUNT OUTPUT ADR
XSDN3:	AOBJN CA,XSDL3		;COUNT POINTER
	PUSHJ P,RPB		;END OF BLOCK. CHECK CKS
	JRST XSDX		;ERR
	CAME W,CKS		;CHECK IT
	PUSHJ P,CKSERR		;ERROR
	JRST XSDL1		;READ ANOTHER POINTER

XSDX:	JRST CLS		;END OF FILE
;FILE SPECIFIER INPUT ROUTINE

FILSPC:	SETZM .DEV		;INITIALIZE
	SETZM .FILE
	SETZM .EXT
	SETZM .TID
	MOVE T,.PSW
	MOVEM T,.TSW		;COPY PERM SW'S
	MOVE T,.PPPN	;AND PPN
	MOVEM T,.TPPN
	MOVE T,.PPRT
	MOVEM T,.TPRT

	TRZ F,R.DOT!R.SW!R.EXT!R.UPA
FILSL:	PUSHJ P,SIXBRD		;READ A WORD
	CAIN CH,":"		;BREAK CHAR
	JRST FILS1
	TRNN F,R.ALL
	JRST FILS2
	TRZE F,R.UPA		;TAPE ID?
	MOVEM W,.TID
	TRZN F,R.DOT
	JRST FILSRE
	MOVEM W,.EXT
	TRO F,R.EXT		;EXPLICIT EXTENSION
FILSRE:	CAIE CH,"←"		;BREAKS?
	CAIG CH,40		; ..
	JRST FILSX
	CAIE CH,","
	CAIN CH,"="
	JRST FILSX
	CAIN CH,"["
	JRST FILSU
	CAIN CH,"<"
	JRST FILSP
	CAIN CH,"."
	JRST FILSD
	CAIN CH,"↑"		;UPARROW?
	JRST FILSUA
	CAIN CH,"/"
	JRST FILSW
	CAIN CH,"("
	JRST FILSS
	JRST FILSL		;LOOP
FILS1:	MOVEM W,.DEV		;SAVE DEVICE
	SETZM .PPPN		;CLEAR PROJ-PROG
	SETZM .TPPN
	SETZM	.PPRT		;CLEAR PROTECTION
	SETZM	.TPRT
	JRST FILSL

FILS2:	SKIPE W			;ANY NAME?
	MOVEM W,.FILE		;YES
	JRST FILSRE

FILSX:	MOVEM CH,.BRKC
	JRST CPOPJ1

FILSU:	PUSHJ P,OCTIN
	CAIE CH,","
	JRST FILSYN		;SYNTAX ERROR
	HRLM N,.TPPN
	SKIPN .FILE
	HRLM N,.PPPN
	PUSHJ P,OCTIN
	CAIE	CH,"]"
	JRST	FILSYN
	HRRM N,.TPPN
	SKIPN .FILE
	HRRM N,.PPPN
	JRST FILSL

FILSP:	PUSHJ P,OCTIN
	CAIE CH,">"
	JRST FILSYN
	HRROM N,.TPRT
	SKIPN .FILE
	HRROM N,.PPRT
	JRST FILSL

FILSUA:	TROA F,R.UPA
FILSD:	TRO F,R.DOT
	JRST FILSL
FILSS:	TRO F,R.SW		;PARENS
FILSW:	PUSHJ P,TYI
	CAIL CH,"A"
	CAILE CH,"Z"		;ONLY LETTERS ARE SWITCHES
	JRST FILSWQ
	SKIPN SWTAB-"A"(CH)
	JRST BADSW
	HRRZ A,SWTAB-"A"(CH)		;GET SWS TO CLR
	ANDCAM A,.TSW		; ..
	SKIPN .FILE		;PERM?
	ANDCAM A,.PSW		;YES
	HLRZ A,SWTAB-"A"(CH)	;GET SET SWS
	IORM A,.TSW
	SKIPN .FILE
	IORM A,.PSW
	TRNE F,R.SW		;PARENS?
	JRST FILSS		;YES
	JRST FILSL		;NO

FILSWQ:	TRZE F,R.SW
	CAIE CH,")"
	JRST BADSW
	JRST FILSL

SIXBRD:	MOVE A,[POINT 6,W]
	MOVEI W,0
SIXBRL:	PUSHJ P,TYI
	CAIN CH,"*"
	JRST SIXLTR
	CAIL CH,"@"
	CAILE CH,"Z"
	SKIPA
	JRST SIXLTR
	CAIL CH,"0"
	CAILE CH,"9"
	POPJ P,0
SIXLTR:	SUBI CH,40
	TLNE A,770000
	IDPB CH,A
	JRST SIXBRL
OCTIN:	MOVEI N,0
OCTINL:	PUSHJ P,TYI
	CAIL CH,"0"
	CAILE CH,"7"
	POPJ P,0
	ASH N,3
	ADDI N,-"0"(CH)
	JRST OCTINL

EOJ:	TRNE	F,R.LST		;WAS A DIRECTORY LISTING REQUESTED
	TLNN	F,L.DTO		;YES--WAS THE OUTPUT A DECTAPE?
	JRST	EOJ1		;NO--SKIP THE OUTPUT
	MOVE	T,ODEV		;COPY OUTPUT DEVICE
	MOVEM	T,IDEV		;  TO INPUT DEVICE
	MOVE	T,OSW		;COPY OUTPUT SWITCHES
	TRO	T,SW.L		;  WITH /L
	MOVEM	T,ISW		;  TO INPUT SWITCHES
				;  AND LEAVE IN T
	TLO	F,L.DTI		;FLAG AS DECTAPE INPUT
	SETOM	EOJFLG		;FLAG AS END-OF-JOB PASS
	JRST	GETDIR		;GO TO DIRECTORY LISTER
EOJ1:	TRNN F,R.JSCR		;WANT TO JUNK SCRATCH?
	JRST EOJE		;NO
	MOVEI A,17		;YES. GET DSK
	MOVSI B,(SIXBIT /DSK/)
	MOVEI C,0
	OPEN SCRF,A
	  JRST EOJE
	MOVE A,SCRNAM
	MOVSI B,(SIXBIT /TMP/)
	SETZB C,D
	LOOKUP SCRF,A
	  JRST EOJE
	SETZB A,B
	SETZB C,D
	CLOSE SCRF,0
	RENAME SCRF,A
	  JFCL
EOJE:	CLOSE SCRF,0
	JRST FILEX
SIXDOT:	PUSHJ P,SIXOUT		;OUTPUT SIXBIT
DOT:	MOVEI CH,"."		;AND A DOT
	JRST TYO

SIXTAB:	PUSHJ P,SIXOUT
TAB:	MOVEI CH,11
TYO:	TTCALL 1,CH
	POPJ P,0

COLON:	MOVEI CH,":"		;TYPE A COLON
	JRST TYO
COMMA:	MOVEI CH,","
	JRST TYO
SPACE:	MOVEI CH," "
	JRST TYO
SIXCR:	PUSHJ P,SIXOUT
CRLF:	MOVEI W,[ASCIZ /
/]
MSG:	HRLI W,440700
MSGL:	ILDB CH,W
	JUMPE CH,CPOPJ
	PUSHJ P,TYO
	JRST MSGL

R5VOUT:	PUSHJ P,R5VSIX		;CONVERT R50 TO SIXBIT IN RH OF T
SIXOU3:	SKIPA T1,[POINT 6,T,17]		;TYPE JUST RH OF T
SIXOUT:	MOVE T1,[POINT 6,T]
SIXL:	ILDB CH,T1
	ADDI CH,40
	PUSHJ P,TYO
	TLNE T1,770000
	JRST SIXL
	POPJ P,0
DATOUT:	JUMPLE A,NODATE
	PUSH P,C
	IDIVI A,↑D31
	MOVEI T,1(B)
	PUSHJ P,DECPR2
	IDIVI A,↑D12
	MOVE T,MONTAB(B)
	MOVEI T1,0
	MOVEI W,T
	PUSHJ P,MSG
	MOVEI T,↑D64(A)
	PUSHJ P,DECPRT
	POP P,C
	POPJ P,0

OCTP4S:	CAIGE T,1000
	PUSHJ P,SPACE
	CAIGE T,100
	PUSHJ P,SPACE
	CAIGE T,10
	PUSHJ P,SPACE
	JRST OCTPRT
;RADIX FIFTY CONVERTER FOR PDP-11 TAPE DIRECTORIES
;NOTE THAT FOR SOME REASON THE CODING OF THIS RADIX 50 IS NOT THE
;SAME AS THAT FOR THE PDP10 (SIGH)

R5VSIX:	SETZM W			;CLEAR ANSWER CELL
	MOVE T2,[POINT 6,W,17]	;POINTER TO OUTPUT
	ANDI T,177777		;MAKE SURE REASONABLE SIZE
	IDIVI T,3100		;GET FIRST CHAR
	PUSH P,T1		;SAVE OTHER 2
	PUSHJ P,R5VOU1		;OUTPUT FIRST
	POP P,T			;RESTORE 2 AND 3
	IDIVI T,50		;SPLIT APART
	PUSH P,T1		;SAVE LAST CHAR
	PUSHJ P,R5VOU1		;OUTPUT SECOND
	POP P,T			;RESTORE THIRD
	PUSHJ P,R5VOU1		;LAST CHARACTER CONVERSION
	MOVE T,W		;ANSWER TO RIGHT AC
	POPJ P,0

R5VOU1:	IDIVI T,6		;USUAL CODE CONVERSION BYTE POINTER HACK
	LDB CH,R5VOU2(T1)	;GET CHAR IN SIXBIT
	IDPB CH,T2		;PUT IN W
	POPJ P,0		;AND RETURN IT

R5VOU2:	POINT 6,R5VTAB(T),5
	POINT 6,R5VTAB(T),11
	POINT 6,R5VTAB(T),17
	POINT 6,R5VTAB(T),23
	POINT 6,R5VTAB(T),29
	POINT 6,R5VTAB(T),35

R5VTAB:	SIXBIT \ ABCDEFGHIJKLMNOPQRSTUVWXYZ$.%0123456789?\
;AND THE REVERSE CONVERSION. CALL WITH 3 SIXBIT CHARS IN RH OF T,
; RETURN WITH RADIX 50 (11 STYLE) IN T (AND W) , ALL BAD CHARS CODED
; AS 35'S, THE UNDEFINED CHAR, WHICH FILEX TREATS AS "%".

SIXR5V:	MOVEI W,0		;CLEAR ANSWER
	MOVE N,[POINT 6,T,17]	;POINT TO INPUT
SXR5VL:	ILDB T1,N		;GET A CHAR
	IDIVI T1,6		;CODE CONVERT
	LDB CH,SXR5V2(T2)	;GET THE R50 BYTE
	IMULI W,50		;LEFT SHIFT PREV BYTES
	ADDI W,0(CH)		;ADD IN THIS ONE
	TLNE N,770000		;DONE?
	JRST SXR5VL		;NO
	MOVE T,W		;YES. ANSWER TO AC T
	POPJ P,0		;AND RETURN

SXR5V2:	POINT 6,SXR5V3(T1),05
	POINT 6,SXR5V3(T1),11
	POINT 6,SXR5V3(T1),17
	POINT 6,SXR5V3(T1),23
	POINT 6,SXR5V3(T1),29
	POINT 6,SXR5V3(T1),35

SXR5V3:	BYTE (6) 0,35,35,35,33,35,35,35,35,35,35,35
	BYTE (6) 35,35,34,35,36,37,40,41,42,43,44,45
	BYTE (6) 46,47,35,35,35,35,35,35,35,01,02,03
	BYTE (6) 04,05,06,07,10,11,12,13,14,15,16,17
	BYTE (6) 20,21,22,23,24,25,26,27,30,31,32,35,35,35,35,35,35,35
DECP4S:	CAIGE T,↑D1000
	PUSHJ P,SPACE
DECP3S:	CAIGE T,↑D100
	PUSHJ P,SPACE
DECP2S:	CAIGE T,↑D10
	PUSHJ P,SPACE
	JRST DECPRT

PROOUT:	PUSH P,T
	MOVEI CH,74
	PUSHJ P,TYO
	POP P,T
	PUSHJ P,OCTPR3
	MOVEI CH,76
	JRST TYO

OCTPR3:	CAIGE T,100
	PUSHJ P,ZEROUT
OCTPR2:	CAIGE T,10
	PUSHJ P,ZEROUT
	JRST OCTPRT

SPACE2:	PUSHJ P,SPACE
	JRST SPACE

CRLF2:	PUSHJ P,CRLF
	JRST CRLF

DATTV:	IDIVI T,↑D31*↑D12		;CONVERT DATES FROM TEN TO ELEVEN
	CAIL T,6
	JRST DATTV1
RETZT:	MOVEI T,0
	POPJ P,0
DATTV1:	IDIVI T1,↑D31
	MOVE N,T
	SUBI T,6		;1970-1964
	MOVEI CH,0
	IMULI T,↑D1000		;1000 TIMES YEARS SINCE 70
DATTV2:	JUMPE T1,DATTV3		;IF TO RIGHT MONTH, JUMP
	ADD T,MONTB2(CH)		;ADD IN A MONTH OF DAYS
	CAIN CH,1		;FEBRUARY
	TRNE N,3		;AND LEAP YR
	SKIPA			;NO
	ADDI T,1		;YES.
	SUBI T1,1		;COUNT DOWN A MONTH
	AOJA CH,DATTV2		;COUNT TABLE INDEX, LOOP
DATTV3:	ADDI T,1(T2)		;ADD IN DAY OF MONTH
	POPJ P,0		;RETURN
DATVT:	JUMPE T,CPOPJ
	IDIVI T,↑D1000
	MOVEI N,2(T)
	IMULI T,↑D372		;DAYS IN A PDP10 YEAR
	ADDI T,↑D2232		;1 JAN 70
	MOVEI CH,0		;MONTH TABLE INDEX
DATVT2:	MOVE T2,MONTB2(CH)
	CAIN CH,1		;FEB?
	TRNE N,3		;LEAP YR?
	SKIPA			;NO
	ADDI T2,1		;YES. IT'S 29 DAYS LONG
	CAMG T1,T2		;IN THIS MONTH?
	JRST DATVT1		;YES
	SUB T1,T2		;NO
	ADDI T,↑D31
	AOJA CH,DATVT2		;LOOP, COUNT MONTH INDEX
DATVT1:	ADDI T,-1(T1)		;ADD IN DAY OF MONTH
	POPJ P,0		;RETURN

OUTLST:	MOVE T,ODEV		;OUTPUT DEVICE
	PUSHJ P,SIXOUT
	PUSHJ P,COLON
	MOVE T,TOFILE
	PUSHJ P,SIXDOT
	HLRZ T,TOEXT
	JRST SIXOU3

CONTQ:	TRNN F,R.GO
	POPJ P,0
	MOVEI W,[ASCIZ \ (CONTINUING - /G) \]
	TRON F,R.GOS
	PUSHJ P,MSG
	PUSHJ P,CRLF
	JRST CPOPJ1
VENDAT:	JUMPG T,VDATE1		;BLANK?
NODATE:	MOVEI W,[ASCIZ /(UNDATED)/]
	JRST MSG
VDATE1:	PUSH P,T		;SAVE DATE
	IDIVI T,↑D1000		;GET DAY OF YEAR
	ADDI T,2		;BECAUSE 1970 WASNT A LEAP YEAR
	MOVEI N,0		;COMPUTE REAL DATE
VDATE3:	MOVE T2,MONTB2(N)	;GET TABLE ENTRY
	CAIN N,1		;FEBRUARY?
	TRNE T,3		;AND LEAP YEAR?
	SKIPA			;NO
	ADDI T2,1		;YES. THE MONTH IS LONGER
	CAMG T1,T2		;IN THIS MONTH?
	JRST VDATE2		;YES
	SUB T1,T2		;MOVE TO NEXT MONTH
	ADDI N,1		;NEXT MONTH
	CAIGE N,14		;PAST DECEMBER?
	JRST VDATE3		;NO. TRY IT.
	POP P,T			;YES. BAD DATE.
	MOVEI W,[ASCIZ /BAD  DATE/]
	JRST MSG

VDATE2:	PUSH P,N
	MOVE T,T1
	PUSHJ P,DECPR2
	POP P,T
	MOVE T,MONTAB(T)
	MOVEI T1,0
	MOVEI W,T
	PUSHJ P,MSG
	POP P,T
	IDIVI T,↑D1000
	ADDI T,↑D70
VDATE5:	CAIG T,↑D99
	JRST VDATE4
	SUBI T,↑D100
	JRST VDATE5
VDATE4:	PUSHJ P,DECPR2
	POPJ P,0

MONTB2:	DEC 31,28,31,30,31,30,31,31,30,31,30,31
MONTAB:	ASCII /-JAN--FEB--MAR--APR--MAY--JUN-/
	ASCII /-JUL--AUG--SEP--OCT--NOV--DEC-/

DECPR2:	CAIG T,11
	PUSHJ P,ZEROUT
DECPRT:	MOVEI CH,12
RDXPRT:	MOVEM CH,RADIX
RDXPRL:	IDIV T,RADIX
	HRLM T1,0(P)
	SKIPE T
	PUSHJ P,RDXPRL
	HLRZ CH,0(P)
	ADDI CH,"0"
	JRST TYO
ZEROUT:	MOVEI CH,"0"
	JRST TYO

TYI:	TTCALL 4,CH		;GET A CHARACTER
	CAILE CH,174		;ALTMODES?
	MOVEI CH,33		;YES.
	CAIE CH,0		;NULL?
	CAIN CH,15		;CARRIAGE RETURN?
	JRST TYI		;YES. SKIP IT
	CAIE CH,40		;SPACE?
	CAIN CH,11		;OR TAB?
	JRST TYI		;YES. SKIP THEM.
	CAIL CH,140		;LOWER CASE?
	TRZ CH,40		;YES. MAKE UPPER CASE.
	CAIN CH,32		;CONTROL Z?
	CALLI 12		;YES. EXIT
	POPJ P,0		;AND RETURN CHARACTER

OCTPRT:	MOVEI CH,10
	JRST RDXPRT

TRMSIX:	MOVSI T1,770000
	MOVSI T2,400000
TRMSXL:	TDNE T,T1
	XOR T,T2
	LSH T1,-6
	LSH T2,-6
	JUMPN T1,TRMSXL
	POPJ P,0
OBVCMR:	PUSHJ P,MOVRT
	PUSHJ P,OBVCOM
	JRST MOVTR

OBVCOM:	MOVSI N,-100		;COUNTER FOR BUFFER LENGTH/2
OBVCL1:	MOVE T,TBUF(N)		;GET A DATA WORD
	MOVNI T1,0(N)		;COUNTER BACK FROM END OF BUFFER
	EXCH T,TBUF+177(T1)	;SWAP TWO WORDS
	MOVEM T,TBUF(N)		; ..
	AOBJN N,OBVCL1		;LOOP THRU WHOLE BUFFE

	SETZM RADIX		;BORROW THIS TEMP TO COUNT TO 200
OBVCL2:	MOVE T,RADIX		;INDEX
	SETCM T2,TBUF(T)	;GET A WORD, COMPLEMENT IT
	MOVEI N,14		;TWELVE 3BIT BYTES
	ROTC T1,-3		;SHUFFLE THEM
	LSHC T,3		; ..
	SOJG N,.-2
	MOVE T2,RADIX		;WHERE IT GOES
	MOVEM T,TBUF(T2)	;STORE IT BACK
	AOS T,RADIX		;COUNT THRU BUFFER
	CAIGE T,200		;DONE YET?
	JRST OBVCL2		;NO. LOOP
	POPJ P,0		;YES. QUIT

READBT:	TLNE F,L.SCRI		;READING FROM SCRATCH FILE?
	JRST RPBSCR		;YES. GO TO DISK ROUTINE
	JUMPE T,READBZ		;SPECIAL HANDLING FOR BLK ZERO
	USETI INF,0(T)		;NORMAL BLOCK. SET IT UP
	INPUT INF,TIOL		;TO TBUF
	STATO INF,740000	;ERRORS?
	AOS 0(P)		;NO. SKIP RETURN
	POPJ P,0		;RETURN

READBZ:	SETSTS INF,174		;FOLLOWING MESS READS BLOCK ZERO
	MOVEI T,TBUF		;PLACE FOR IT AND RING HDR
	EXCH T,.JBFF
	INBUF INF,1		;GET BUFFER
	MOVEM T,.JBFF		;RESTORE .JBFF
	USETI INF,0		;SET FOR BLK 0
	INPUT INF,0		;READ THE BLOCK
	GETSTS INF,T		;SEE IF ANY ERRORS
	SETSTS INF,117		;BACK TO REGULAR KLUDGE IO MODE
	TRNE T,740000		;ERRORS?
	POPJ P,0		;YES. NON-SKIP RETURN
	HRLZ T,IHED2+1		;GET START OF DATA
	HRRI T,TBUF		;MOVE IT DOWN WHERE IT BELONGS
	BLT T,TBUF+177		; ..
	JRST CPOPJ1		;SKIP RETURN - SUCCESSFUL
;OUTPUT WBUF TO BLOCK IN OBLK, ON DSK SCRATCH OR DTA AS APPROPRIATE

PPBBLK:	TLNE F,L.SCRO		;OUTPUTTING TO TAPE OR DSK?
	JRST PPBSCR		;DISK
	SKIPN OBLK		;TAPE. IS IT BLK 0?
	JRST PPBB0		;YES.
	USETO OUTF,@OBLK	;SET FOR BLK
	OUTPUT OUTF,WIOL	;PUT OUT WBUF
	STATZ OUTF,740000	;ERRORS?
	JRST ERR19		;YES
	POPJ P,0		;NO

PPBB0:	PUSHJ P,WBK0		;GET THE TAPE, WRITE BK 0
	  JRST ERR19		;TAPE ERROR
	POPJ P,0

PPBSCR:	MOVE T,OBLK		;GET OUTPUT BLK
	USETO SCOF,1(T)		;RIGHT BLK ON DSK
	OUTPUT SCOF,WIOL	;SEND THE DATA
	STATZ SCOF,760000	;TROUBLE?
	JRST ERR3		;YES.
	POPJ P,0		;NO. RETURN

CLRWBF:	MOVE T,[XWD WBUF,WBUF+1]
	SETZM WBUF		;CLEAR BUFFER FOR NEXT BLK
	BLT T,WBUF+177		; ..
	POPJ P,0

ROBTOD:	MOVEM T,ODIBKN		;SAVE BLK NUMBER IN ODIREC
	PUSHJ P,ROUTBT		;READ TO TBUF
	  SOS 0(P)		;ERROR
	MOVE T,[XWD TBUF,ODIREC]
	BLT T,ODIREC+177	;COPY TO ODIREC BUFFER
	JRST CPOPJ1		;OK RETURN
RBTDIR:	PUSHJ P,READBT		;READ BLOCK IN T INTO TBUF
	  SOS 0(P)		;SET FOR ERROR RETURN
	MOVE T,[XWD TBUF,DIRECT]	;OK. COPY IT TO DIRECTORY BLOCK
	BLT T,DIRECT+177	; ..
	JRST CPOPJ1		;SUCCESS RETURN

RBTRBF:	PUSHJ P,READBT		;READ THE BLOCK INTO TBUF
	  SOS 0(P)		;SET FOR ERROR RETURN
	MOVE T,[XWD TBUF,RBUF]	;COPY INTO READ BUFFER
	BLT T,RBUF+177		; ..
	JRST CPOPJ1		;RETURN

MOVRT:	MOVE T,[XWD RBUF,TBUF]
	BLT T,TBUF+177
	POPJ P,0

MOVTR:	MOVE T,[XWD TBUF,RBUF]
	BLT T,RBUF+177
	POPJ P,0
WBK0:	PUSH P,A		;SAVE WORK AC'S
	PUSH P,B		; ..
	PUSH P,C		; ..
	MOVEI A,174		;NOW WRITE ON THE TAPE. KLUDGE FOR BK 0
	MOVE B,ODEV
	MOVSI C,OHED2		;HEADER FOR BK 0 WRITER
	OPEN OUTF,A
	  JRST ERR14
	POP P,C			;RESTORE THEM
	POP P,B			; ..
	POP P,A			; ..
	PUSH P,.JBFF		;GET A BUFFER FOR BLK 0
	MOVEI T,TBUF		;IN TBUF
	MOVEM T,.JBFF
	OUTBUF OUTF,1		;ONE BUFFER
	POP P,.JBFF		;RESTORE
	USETO OUTF,0		;WRITE BLK 0
	OUTPUT OUTF,0		;GET USE BITS RIGHT
	SOS OHED2+1		;MODIFY LINK WD
	MOVE T,WIOL		;COPY WBUF TO TBUF
	MOVE T1,1(T)		;GET A WORD
	IDPB T1,OHED2+1		;COPY IT TO TBUF
	AOBJN T,.-2		;COPY 128 WDS
	SETZM OHED2+2		;WROTE ALL WDS
	OUTPUT OUTF,0		;WRITE IT ON TAPE
	STATZ OUTF,740000	;ERRORS?
	  POPJ P,0		;YES. LOSE
	SETSTS OUTF,117		;OK. RETURN TO DUMP MODE
	JRST CPOPJ1		;GOOD RETURN

ROUTBT:	TLNE F,L.SCRO		;SCRATCH OUTPUT FILE OPEN?
	JRST ROBT1		;YES
	USETI OUTF,0(T)		;NO. READ FROM TAPE, BLK IN T
	INPUT OUTF,TIOL		;READ THE BLOCK TO TBUF
	STATO OUTF,740000	;TROUBLE?
	AOS 0(P)		;NO. SKIP RETURN
	POPJ P,0

ROBT1:	USETI SCOF,1(T)		;SELECT BLOCK VIA T
	INPUT SCOF,TIOL		;READ TO TBUF
	STATO SCOF,740000	;OK?
	AOS 0(P)		;OK. SKIP RETURN
	POPJ P,0		; ..
;ERROR ROUTINES

ERR1:	PUSH P,B
	.EMSG <? CAN'T ACCESS INPUT DEVICE >
	POP P,T
	PUSHJ P,SIXOUT
	JRST FILEX
ERR2:	.EMSG <? ERROR READING TAPE DIRECTORY>
	JRST FILEX
ERR3:	.MSG <% CAN'T ACCESS DSK FOR SCRATCH FILE
>
	JRST TYPDIQ
ERR4:	.MSG <% CAN'T ENTER SCRATCH FILE ON DISK
>
	JRST TYPDIQ
ERR5:	.EMSG <? BAD FREE COUNT ON PDP6 DIRECTORY>
	JRST FILEX
ERR6:	.MSG <% I/O ERROR READING TAPE - CONTINUING
>
	JRST TYPDIQ
ERR7:	.MSG <% I/O ERROR WRITING SCRATCH FILE - CONTINUING
>
	JRST TYPDIQ
ERR8=ERR3
ERR9:	.EMSG <? CAN'T OPEN OUTPUT DEVICE>
	JRST FILEX
ERR10:	.EMSG <? ERROR ON OUTPUT DEVICE>
	GETSTS OUTF,T
	PUSHJ P,OCTPRT
	JRST FILEX
ERR11:	.EMSG <? COMMAND ERROR - NO * ON OUTPUT WITH MULTIPLE INPUT>
	JRST FILEX
ERR12:	.EMSG <? CAN'T ACCESS DSK FOR UFD>
	JRST FILEX
ERR13:	.EMSG <? I/O ERROR READING UFD>
	JRST FILEX
ERR14=ERR9
ERR15:	.EMSG <? CAN'T ENTER FILE >
	MOVE T,A
	PUSHJ P,SIXDOT
	MOVE T,B
	PUSHJ P,SIXCR
	JRST FILEX
ERR16:	TRNE F,R.ABC		;ALWAYS BAD CKSM?
	JRST ERR16C		;YES. CONSIDER WHAT BIT
ERR16B:	TROE F,R.GOS		;ERROR. FIRST?
	JRST ERR16E		;NO
ERR16A:	TRNN F,R.GO		;/G?
	JRST ERR16D		;NO. GIVE FATAL MESSAGE
	.MSG <% I/O ERROR READING INPUT FILE - CONTINUING (/G)
>
ERR16E:	GETSTS INF,T
	TRZ T,740000
	SETSTS INF,0(T)
	POPJ P,0		;YES
ERR16C:	STATZ INF,340000	;ERRORS BESIDES CKSM?
	JRST ERR16B		;YES. GIVE MESSAGE
	POPJ P,0		;NO. IGNORE ERROR.
ERR16D:	.EMSG <? I/O ERROR READING INPUT FILE
>
	JRST FILEX
ERR17:	.EMSG <? ERROR READING DISK SCRATCH FILE
>
	POPJ P,0
ERR18:	.EMSG <? BAD LINK BLOCK NUMBER ON TAPE
>
	POPJ P,0
ERR19:	.EMSG <? ERROR ON OUTPUT DEVICE>
	JRST FILEX
ERR20:	.EMSG <? OUTPUT TAPE FULL
>
	JRST CLS
ERR21=ERR10
ERR22:	TRNN F,R.OUT		;ANY OUTPUT SPEC?
	CAIL T,40		;NO. END OF LINE?
	SKIPA			;BAD
	JRST FILEX		;BLANK LINE. IGNORE IT
	.EMSG <? COMMAND ERROR - NO ← OR =AFTER OUTPUT FILE>
	JRST FILEX
ERR23:	.EMSG <? NO SUCH FILE AS >
	MOVE T,IFILE
	PUSHJ P,SIXDOT
	MOVE T,IEXT
	PUSHJ P,SIXCR
	JRST EPROCS
ERR24:	.EMSG <? NON-MONOTONIC INPUT DATA
>
	JRST CLS
ERR25:	.MSG <PROTECTION RENAME FAILED
>
	POPJ P,0
ERR26:	.EMSG <? CAN'T ACCESS INPUT DEVICE>
	JRST FILEX
ERR27:	.EMSG <? TAPE DIRECTORY FULL>
	JRST FILEX
ERR28:	PUSH P,XBUF+3		;SAVE ERROR CODE
	SKIPA
ERR29:	PUSH P,B		;SAVE ERROR CODE
	.EMSG <? LOOKUP FAILURE (>
	POP P,T
	HRRZS T
	PUSHJ P,OCTPR2
	.MSG <) FILE >
	MOVE T,A
	PUSHJ P,SIXDOT
	MOVE T,B
	PUSHJ P,SIXCR
	JRST EPROCS		;TRY TO CONTINUE IF MULT FILES
ERR30:	.EMSG	<? PROTECTION ILLEGAL ON INPUT FILE>
	JRST	FILEX
ERR31:	.EMSG	<? TAPE ID ILLEGAL ON INPUT FILE>
	JRST	FILEX
ERR32:	.EMSG <? ERROR READING OUTPUT SCRATCH FILE
>
	JRST FILEX
ERR33:	.EMSG <? ERROR WRITING SCRATCH FILE FOR OUTPUT TAPE
>
	JRST FILEX
ERR34:	.EMSG <? CAN'T READ OUTPUT SCRATCH FILE
>
	JRST FILEX
ERR35:	.EMSG <?I/O ERROR ON OUTPUT SCRATCH FILE
>
	JRST FILEX
ERR36:	.EMSG <? CAN'T PROCESS DIRECTLY BETWEEN 16 & 18 BIT MACHINE TAPES.
>
	JRST FILEX
ERR37:	.EMSG <? ILLEGAL VALUE FOR PDP11 UIC
>
	JRST FILEX
ERR38:	.EMSG <? CONSISTENCY CHECK IN PDP11 TAPE DIRECTORY
>
	JRST FILEX
ERR39:	.MSG <% ERROR READING BLOCK 0 - CONTINUING
>
	POPJ P,0
ERR40:	.EMSG <? ERROR ON OUTPUT DIRECTORY
>
	JRST EPROCS
ERR41:	.EMSG <? DECTAPE SWITCH ON NON-DECTAPE INPUT DEVICE
>
	JRST FILEX

ERR42:	.EMSG <? DECTAPE SWITCH ON NON-DECTAPE OUTPUT DEVICE
>
	JRST FILEX

ERR43:	.MSG <% ZERO SWITCH ON INPUT DEVICE IGNORED
>
	POPJ P,0

ERR44:	.EMSG <? OUTPUT DEVICE NOT A BINARY DEVICE>
	JRST FILEX

ERR45:	.EMSG <? INPUT DEVICE NOT A BINARY DEVICE>
	JRST FILEX

ERR46:	.EMSG <? ENTER FAILURE >
	HRRZ T,B
	PUSHJ P,OCTPRT
	.MSG < ON OUTPUT >
	PUSHJ P,OUTLST
	PUSHJ P,CONTQ		;/G?
	  JRST FILEX
	JRST EPROCS		;YES

ERR47:	.EMSG <? DEVICE >
	MOVE T,ODEV
ERR47A:	PUSHJ P,SIXOUT
	.MSG < DOES NOT EXIST>
	JRST FILEX
ERR48:	.EMSG <? DEVICE >
	MOVE T,IDEV
	JRST ERR47A
HELP:	MOVEI W,HELPM
	PUSHJ P,MSG
	JRST FILEX

HELPM:	ASCIZ \COMMANDS ARE OF THE FORM:
DEV:FILE.EXT[P,PN]<PROT>/S←DEV:FILE.EXT[P,PN]/S

"=" IS THE SAME AS "←"
THE INPUT (RIGHT-HAND) SIDE MAY HAVE MORE FILES IN THE SAME FORMAT,
 SEPARATED BY COMMAS.
DEV: DEFAULTS TO DSK:
FILE, .EXT DEFAULT TO *
 BUT .TMP FILES ARE NOT INCLUDED IN .* WHEN READING FROM DSK:.

PROT DEFAULTS TO SYSTEM STANDARD, <233> ON PDP11 TAPES
/S IS A SWITCH LETTER
(SSSS) IS OK FOR MULTIPLE SWITCHES

FILES ARE TRANSFERRED IN BINARY AND INDIVIDUALLY AT ALL TIMES,
 EXCEPT IN SOME CASES OF /V AND /F

SWITCHES ARE:

/A FORCES ASCII PROCESSING OF /V AND /F FILES
/B FORCES BINARY FILE TRANSFERS
/C SAYS FILE IS COMPRESSED (PDP10 .SAV)
/D SAYS FILE IS PDP6 .DMP FORMAT
/E SAYS FILE IS PDP10 .XPN FORMAT
/F SAYS TAPE IS A PDP FIFTEEN TAPE
/G SAYS GO ON IN CASE OF I/O ERRORS
/H SAYS HELP MESSAGE (NO FILE TRANSFERS ARE DONE)
/I FORCES IMAGE MODE ON /V TAPES
/L SAYS LIST FILE DIRECTORY OF TAPE (DO NOT SAY TTY:. THAT'S ASSUMED.)
/M SAYS TAPE IS PROJECT MAC FORMAT
/O SAYS TAPE IS OLD PDP6 FORMAT
/P SAYS SAME AS /Q BUT PRESERVE THE TEMP FILE IF ON INPUT TAPE
/Q SAYS QUICK MODE PROCESSING (COPY IN BIG GULPS BETWEEN DSK AND TAPE)
  BUT /Q IS NOT BELIEVED ON OUTPUT UNLESS /Z APPEARS TOO
/R SAYS SAME AS /Q BUT RE-USE TEMP FILE SAVED BY AN EARLIER /P
/S SAYS FILE IS A PROJECT MAC SAVE FILE (SBLK)
/T SAYS TAPE IS A NORMAL PDP TEN TAPE
/V SAYS TAPE IS A PDP-ELE-V-EN TAPE
/Z SAYS ZERO THE TAPE
 "↑TAPEID" OR "[P,PN]" MAY APPEAR WITH /Z FOR TAPES WHERE THIS
 IS MEANINGFUL.

IN THE EVENT NO SWITCHES DIRECT PROCESSING, FILE EXTENSIONS CAUSE THE
RIGHT THING TO HAPPEN IN THE FOLLOWING CASES:
.DMP IMPLIES /D
.SAV, .LOW, .SVE IMPLY /C
.XPN IMPLIES /E
THESE FILE EXTENSIONS ARE IMPLIED FOR OUTPUT FILES WITH THOSE
SWITCHES TOO, AS IS .BIN FOR /S.

IN THE CASE OF /V, THE FOLLOWING EXTENSIONS IMPLY /B PROCESSING:
.BIN, .OBJ, .SYS, .LDA, .LDR, .LOD, .LBO, .MFD, .UFD, .SYM
OTHERWISE, /A IS ASSUMED

IN THE CASE OF /F, .ABS IMPLIES /B (NOT IOPS), AND .BIN IMPLIES
IOPS BINARY TRANSFERS. OTHERWISE, IOPS ASCII IS ASSUMED FOR OUTPUT
TO /F, AND IOPS HEADERS ARE CHECKED FOR INPUT FROM /F.

\

CKSERR:	.MSG <MAC FILE CHECKSUM ERROR - CONTINUING
>
	POPJ P,0
FILSYN:	.EMSG <? EH?
>
	POPJ P,0
BADSW:	PUSHJ P,TYO
	.MSG < IS A BAD SWITCH
?>
	POPJ P,0
NOTYET:	.EMSG <? FEATURE NOT YET IMPLEMENTED>
	JRST FILEX
;TEMPORARIES

STATES:	0
IDEV:	0
IPPN:	0
IFILE:	0
TIFILE:	0
IEXT:	0
TIEXT:	0
DTFMTI:	0
SCRNAM:	0
LASTBK:	0
SJFF:	0			;.JBFF FOR UFD FOR WILDCARD LOOKUP
SJFF2:	0			;.JBFF FOR INPUT BUFFER BASE
SJFF3:	0			;.JBFF AS SEEN FOR OUTPUT BUFFER BASE
SJFF4:	0			;.JBFF AS SEEN BY RPBSCR RTN
BLKS:	0
ODEV:	0
OFILE:	0
TOFILE:	0
OEXT:	0
FOEXT:	0
TOEXT:	0
OPPN:	0
OPRT:	0
IDATE:	0
ODATE:	0
IBLK:	0
OBLK:	0
OSW:	0
ISW:	0
OFILEX:	0
IFILEX:	0
OCA:	0
ICA:	0
.DEV:	0
.FILE:	0
.EXT:	0
.PPPN:	0
.TPPN:	0
.PPRT:	0
.TPRT:	0
.PSW:	0
.TSW:	0
.BRKC:	0
OFIRBK:	0
OFIRBP:	0
OFIL1V:	0			;NAME1 OF VEN OUT FILE IN R50VEN
OFIL2V:	0			;SECOND HALF NAME
OEXTV:	0			;AND EXT
RADIX:	0
OTYPEX:	0
ITYPEX:	0
SRCHP:	0
SRCHPM:	0
OFILEL:	0
IMACP:	0
OMACP:	0
.TID:	0
OTID:	0
SCRBK1:	0
EOJFLG:	0
FTEMP:	0
FCOUNT:	0
MFDPPN:	0			;PPN TO FIND UFD'S
SYSPPN:	0			;PPN FOR SYS ON DSK
FBMX:	0
FBMBLK:	0			;BLOCK NUMBER FOR BIT MAP FOR CURRENT OUTPUT FILE
PBMBKI:	0			;BLK NUMBER FOR MASTER BIT MAP ON VEN TAPE
PBMBKO:	0			;SAME FOR OUTPUT VEN TAPE
TBBLK:	0			;BLOCK WHICH IS CURRENTLY IN TBUF
OBVFLG:	0			;FLAG NEED OBVCOM OF PREV BLK
IOPSOC:	0
IOPSOP:	0
FOTXP1:	0
FOTXP2:	0
FOTXW1:	0
FOTXW2:	0
IOPSOB:	BLOCK 200
VBMAPO=IOPSOB			;ELEVEN OUTPUT MASTER BIT MAP IN SAME SPACE
FITXP1:	0
FITXP2:	0
FITXW1:	0
FITXW2:	0
XFILFQ:	0
SAVSTA:	0			;START ADDR WHEN MAKING A SAV FILE
DIRBKN:	0			;BLK NUMBER CURRENTLY IN DIRECT BUFFER
ODIBKN:	0			;BLK NUMBER CURRENTLY IN ODIREC BUFFER
VENPPI:	0			;PPN (UIC) OF INPUT VEN TAPE
VOUIC:	0			;VEN OUTPUT USER ID CODE
VWPEI:	0			;VEN WORDS PER ENTRY IN UFD ON INPUT TAPE
VWPEO:	0			;VEN WDS PER UFD ENTRY OUTPUT TAPE
VIFFIL:	0			;INPUT FILE NAME FOR CURRENT VEN DIRECT SLOT IN SIXBIT
VIFEXT:	0			;INPUT FILE EXT IN SIXBIT ...
VDIRB1:	0			;FIRST REAL DATA BLK OF VEN DIR
VDIRB2:	0			;SECOND .. ..
VODIB1:	0			;FIRST REAL DATA BLK OF OUTPUT VEN DIR
VODIB2:	0			;SECOND ...
VENFBN:	0			;FIRST BLOCK NUMBER (AFTER A LOOKUP)
RPAVC1:	0			;FLAG FOR WHICH BYTE OF WORD
RPAVW1:	0			;WORD HELD BETWEEN TWO RPA'S
DIRIOW:	IOWD 200,DIRECT
	0
DIRECT:	BLOCK 200
ODIIOW:	IOWD 200,ODIREC
	0
ODIREC:	BLOCK 200

WIOL:	IOWD 200,WBUF
	0
WBUF:	BLOCK 200
RBUF:	BLOCK 200

IHED2:	BLOCK 3
OHED2:	BLOCK 3

TIOL:	IOWD 200,TBUF
	0
;DO NOT SEPARATE - NEEDED FOR BLOCK ZERO READER
TXIOL:	IOWD 400,TBUF
	0
TBUF:	BLOCK 200
XBUF:	BLOCK 200
;END DO NOT SEPARATE
FBMBUF:	BLOCK 200
EVSPOS=FBMBUF+37		;POSITION IN THE DIRECTORY BLOCK OF THIS SLOT
EVSLOT=FBMBUF+40		;SLOT FOR OUTPUT VEN ENTRY
EVSN1=EVSLOT+0			;NAME FIRST THREE CHARS
EVSN2=EVSLOT+1			;SECOND THREE
EVSEXT=EVSLOT+2			;EXTENSION
EVSDAT=EVSLOT+3			;DATE
EVSFBN=EVSLOT+5			;FIRST BLOCK IN FILE
EVSLEN=EVSLOT+6			;NUMBER OF BLOCKS
EVSLAS=EVSLOT+7			;LAST BLOCK
EVSPRT=EVSLOT+10		;PROTECTION CODE
CORIOW:	0
	0

IHED:	BLOCK 3
OHED:	BLOCK 3
UHED:	BLOCK 3

LASTOB:	1101		;CONST FOR NOW
PDP:	IOWD 20,PDL
PDL:	BLOCK 20

	XLIST			;LITERALS
	LIT
	LIST

FILEXX:
	END FILEX		;END OF FILEX